自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

優(yōu)秀軟件設(shè)計的基本元素是什么?

開發(fā) 前端
在本文中,我想詳細介紹優(yōu)質(zhì)軟件設(shè)計的廣泛概念,而不是因語言而異的細節(jié)。

在本文中,我想詳細介紹優(yōu)質(zhì)軟件設(shè)計的廣泛概念,而不是因語言而異的細節(jié)。

什么時候代碼好而什么時候壞? 這是一個主觀且有爭議的話題。 有許多特定于語言或框架的規(guī)則和準則,但是我堅信,好的代碼或好的設(shè)計不僅或總是與它們相關(guān)。 通常,它們會使代碼變得復(fù)雜,分散且結(jié)構(gòu)過度。 因此,我相信好的設(shè)計取決于它的用例。

幸運的是,我認為仍然有一些方法可以確定該軟件在其使用案例中是"好"還是"壞"。

好的設(shè)計很簡單

通常,我遇到的代碼具有完美的結(jié)構(gòu),并具有適當(dāng)?shù)慕涌冢⒉捎昧诉m當(dāng)?shù)慕涌?,并且采用了特定的代碼模式和代碼樣式工具,這些工具不會返回單個錯誤或警告。 但是,我仍然認為這很糟糕。

每次寫東西時,都應(yīng)該成比例。 許多開發(fā)人員只是為了模式而采用模式。 他們幾乎在大喊:"看看我在采用我剛剛讀過的這種模式方面有多強",而不是真正理解他們?yōu)槭裁催x擇特定模式。

好的設(shè)計通常很簡單。 我的意思是與他們提供的解決方案的大小成正比。 如果您為應(yīng)用程序提供僅使用一次的簡單功能,那么您是否應(yīng)該使用各種花哨的東西? 考慮一下您的代碼復(fù)雜度是否與您提供的解決方案成比例。 您的功能將成為應(yīng)用程序的骨干,還是應(yīng)用程序中擴展或繼承的基礎(chǔ)? 您最好使其結(jié)構(gòu)合理。 這僅僅是解決您的應(yīng)用程序中的一個小問題的方法嗎? 最好盡可能地簡單。

我們傾向于過于復(fù)雜化我們的功能

與我們的應(yīng)用程序的項目負責(zé)人交談時,我們會檢索需求。 在首先提出實現(xiàn)想法之后,我們常常使方法的初始設(shè)計過于復(fù)雜。 與幾個開發(fā)人員坐下來并深入研究實際需要的東西通常是有益的。 您可以通過幾種方法來確保提供更簡單的解決方案。

正確的問題

作為開發(fā)人員,我們經(jīng)常被要求做某事,而我們只是這樣做。 這種按需行為對于初級開發(fā)人員而言可能是正常的,但是隨著您的前進,請嘗試提出明智的問題,并確保在估計或設(shè)計解決方案之前已回答了這些問題。 當(dāng)您一遍又一遍地問某些問題時,您還培訓(xùn)您的產(chǎn)品負責(zé)人或管理人員在請求功能之前考慮這些問題。 像這樣的問題:

  • 此功能的最終目標是什么?
  • 誰將使用它?
  • 有沒有更簡單的方法可以實現(xiàn)相同的目標?
  • 它將使應(yīng)用程序更大,更復(fù)雜嗎? 值得嗎?

將解決方案分為多個部分

我始終要做的第一件事是遠離需要在其中實現(xiàn)功能的應(yīng)用程序。然后考慮一下您可以制作和交付的最小代碼段,這使您更加接近為此功能設(shè)置的目標。 對所有這些都執(zhí)行此操作,重新評估所有步驟是否必要,并分別估計其開發(fā)時間。 另外,請嘗試以盡可能獨立的方式開發(fā)這些元素。 交換功能,更改或刪除功能越容易,編寫代碼就越容易。

如果某些必要的小功能真的很重要,請?zhí)魬?zhàn)產(chǎn)品負責(zé)人

當(dāng)您將方法劃分為小部分時,與非技術(shù)人員進行討論通常會更容易。 這樣就可以與團隊和產(chǎn)品負責(zé)人進行討論,并重新評估是否需要所有部分。 由于您已經(jīng)估算了它們,因此如果功能值得,則可以做出更好的基于價值的決策。

不要忘記估計它增加的復(fù)雜程度以及它如何影響維護應(yīng)用程序的成本。

好的代碼很容易更改

如果代碼易于更改,則維護成本較低,易于理解,擴展,刪除,甚至可以更改! 就像《實用程序員》一書中所寫:"如果事物能夠適應(yīng)使用它的人,那么它就是經(jīng)過精心設(shè)計的。" 本質(zhì)上,所有設(shè)計原則都是使代碼更易于更改的一種方式。 解耦,單責(zé)任原則,干。 這些都是使您的代碼更好,更容易更改的原則。

為什么我討厭代碼中的注釋

當(dāng)您需要注釋代碼時,它基本上很爛。 當(dāng)您需要解釋為什么要執(zhí)行某項操作時,該代碼并不是不言自明的,因此無論如何都應(yīng)該對其進行重構(gòu)。 代碼注釋清楚地表明了錯誤代碼,并且可以采取許多簡單的步驟使代碼更具可讀性。

注釋不能彌補混亂的代碼。 當(dāng)代碼令人困惑或做出危險的假設(shè)時,我們傾向于寫一些額外的注釋。

唯一有意義的注釋是:

  • 法律評論
  • 目的說明
  • 提高可讀性
  • 警告后果
  • 待辦事項

如何編寫更好的代碼

有許多簡單的原則可以幫助您編寫更輕松的代碼,而您的同事會喜歡并喜歡與他們一起工作。 對于其中的每一個,都可以編寫一個完全獨立的文章,因此,這里有一個簡單的清單,可以開始您邁向更好的代碼。

類應(yīng)該很小。 多么小? 盡可能小。 一個類應(yīng)該只承擔(dān)一個責(zé)任,并且其名稱應(yīng)從該責(zé)任派生。 如果您無法想到一個具有邏輯性和描述性的類名,則它可能太大。

方法/功能

像類一樣,它們應(yīng)該很小,只做一件事,并具有解釋性和簡單的名稱。 注意標識。 許多縮進通常是一種凌亂方法的跡象。 對于Foreach和switch語句,請確保將實際執(zhí)行的代碼編寫在單獨的函數(shù)中,這使其更像是該方法針對不同實現(xiàn)實際執(zhí)行的操作的索引。

有意義的名字

類,函數(shù)和變量都應(yīng)具有有意義的名稱。 例如,切勿使用$ a = b;。 讓您的代碼成為功能和意圖的文檔。

格式和代碼樣式

確保您的整個應(yīng)用程序和整個團隊使用完全相同的代碼樣式,并且對此非常嚴格。 每種IDE和語言都有用于此目的的工具。 一致的空格或換行符可以起到很大作用。 如果不一致,則會使您發(fā)瘋。 在這方面非常嚴格將立即提高應(yīng)用程序的整潔度,尤其是在這方面不是很嚴格的語言中。

 

責(zé)任編輯:趙寧寧 來源: 今日頭條
相關(guān)推薦

2012-03-15 10:04:06

移動web

2010-06-13 10:56:13

UML文獻

2016-10-18 21:39:59

Semantic-UIReact基本元素組件

2017-08-28 15:00:20

軟件系統(tǒng)架構(gòu)風(fēng)格

2013-05-08 09:12:44

2011-01-25 10:59:00

軟考軟件設(shè)計師

2018-01-23 08:24:57

HTTPS服務(wù)器加密

2020-12-11 09:38:49

Shell編程開發(fā)

2012-12-24 08:50:21

iOSUnity3D

2019-08-12 14:45:50

軟件設(shè)計Java

2009-07-01 15:08:50

JSP指令和腳本元素

2010-06-24 14:39:09

HART協(xié)議

2016-10-18 21:45:53

Semantic-UIReactJavascript

2013-06-07 11:31:36

面向?qū)ο?/a>設(shè)計模式

2010-06-28 15:23:43

SNMP協(xié)議

2012-06-07 10:17:55

軟件設(shè)計設(shè)計原則Java

2021-11-23 20:41:05

對象軟件設(shè)計

2014-06-17 09:42:05

軟件開發(fā)軟件設(shè)計

2020-03-23 10:09:27

云安全云計算

2012-04-16 15:14:47

web設(shè)計
點贊
收藏

51CTO技術(shù)棧公眾號