軟體開發的程式設計師都應該懂的原則
在當今網際網路飛速發展的時代,作為一個合格的軟體開發程式設計師,你必須要了解你所從事的工作是有一定的原則的,你的按照這個原則來進行工作,否則整個行業會將你淘汰。

1:存在的原因
軟體系統存在的原因:為使用者提供價值。所有的決定都應該考慮到這一點。在指定系統需求之前,在關注系統的各個功能之前,在確定硬體平臺或開發過程之前,問問自己以下問題:這是否能為系統真正增加價值?如果答案是否定的,那就不要去做。所有其他原則都以這一條為先。

2:簡單而不缺內容
軟體設計不是一個偶然的過程。任何設計工作都需要考慮許多因素。所有的設計應該儘可能簡單,但不要過於簡化。複雜性是你的敵人。任何傻瓜都能讓事情變得複雜。反之則很難。
這有利於擁有更易於理解和易於維護的系統。但並不是說應該以簡單的名義拋棄功能,甚至是內部功能。當然,通常而言,更優雅往往意味著更簡單。簡單是終極的複雜。
簡單也並不意味著快速和骯髒。事實上,為了簡化,我們經常需要大量思考和多次迭代工作。收穫是更易於維護且不易出錯的軟體。

小編是一個有著多年工作經驗的前端工程師,今年年初我花了一個月整理了一份最適合2019年學習的前端學習乾貨,從最基礎的到深入的都有整理,送給每一位想學習的小夥伴。 進我的企鵝群: #/Writing; 9567 ,。、- 66604 免費送給大家,希望你也能憑著自己的努力,成為下一個優秀的程式設計師
學習路線:

3:維護願景
明晰的願景對於軟體專案的成功至關重要。否則,專案最終基本上都將陷入左右搖擺的境地。沒有概念的完整性,系統就很有可能成為不相容設計的拼湊物——被錯誤的螺絲釘連線在一起。
概念完整性是系統設計中要考慮的最重要因素。
妥協軟體系統的架構願景會削弱並將最終破壞系統,甚至是設計得盡善盡美的系統。擁有一個能夠實現願景和執行合規性的授權架構師有助於確保軟體專案的成功。

4:生產其他人消費的東西
很少有工業級的軟體系統是在真空中構建和使用的。其他人將以某種方式,或者其他依賴於能夠理解系統的方式使用、維護、記錄。因此,始終指定、設計,以及實現瞭解他人將有助於瞭解你在做什麼。任何軟體開發產品的受眾都可能很大。關注那些必須維護和擴充套件系統的程式碼。有的人可能需要除錯你編寫的程式碼,這使得他們成為你的程式碼使用者。方便他們工作可以為你的系統增添價值。

5:面向未來
壽命較長的系統具有更大的價值。在今天的計算環境中,當規格在剎那間發生變化並且硬體平臺過幾個月就變得過時時,軟體壽命常常用月來衡量而不是用年。然而,真正的工業級軟體系統必須能堅持更長時間。要做到這一點,系統必須能夠適應這些改變。可以成功實現這些目標的系統都是從一開始就以這種方式而設計的。切勿在設計時自找麻煩。總是問“假使這樣,那會怎麼樣”,並通過建立解決一般問題,而非僅僅是具體問題的系統來準備好所有可能的答案。這很可能促使整個系統的重用。

6:預先規劃重用
重用可節省時間和精力。實現高水平的重用可以說是開發軟體系統最難的目標。程式碼和設計的重用已被宣稱為使用面向物件技術的主要優勢。但是,這項投資的回報並不是自動的。為了利用面向物件程式設計提供的重用可能性,我們需要預先考慮和規劃。在系統開發過程的每個級別都有很多技術可以用來實現重用。詳細設計和程式碼級別的重用技術不但眾所周知而且是有文件的。
7:三思而後行!
這最後一條原則可能是最容易被忽視的。在行動之前形成一條清晰和完整的思路幾乎總能夠產出更好的結果。只有你考慮到了某個問題,你才更有可能解決它。你還可以從中獲得有關如何再次正確做這件事的知識。
如果你確實考慮到了某件事情,但仍然做錯了,那麼這就是你寶貴的經驗。思考還有一個成果是可以學習到當你不知道某個東西,此時該如何研究答案的過程。明確的思想進入到系統,就會產出價值。應用前六個原則需要深入的思考,當然潛在的回報也是不可估量。