[導讀]在代碼中用一堆嵌套,從高花大量時間寫出漂亮的身上代碼但最后才發(fā)現無法運行,不給任務留緩沖時間…… 這是編碼很多新手程序員都踩過的雷。在這篇文章中,原則一位全棧首席開發(fā)者總結了高級開發(fā)人員的從高19個編碼原則,可以幫助新手少踩些坑。身上
在代碼中用一堆嵌套,編碼花大量時間寫出漂亮的原則代碼但最后才發(fā)現無法運行,不給任務留緩沖時間…… 這是從高很多新手程序員都踩過的雷。在這篇文章中,身上一位全棧首席開發(fā)者總結了高級開發(fā)人員的編碼 19 個編碼原則,可以幫助新手少踩些坑。原則

進行軟件開發(fā),從高整天敲代碼、身上好不容易調試成功,編碼但是代碼的質量堪憂,可讀性不是很高,反過頭來還得對代碼進行完善。 也許這不是你的編碼能力問題,很有可能在你進行代碼編寫時,一些看似不重要的編碼注意事項沒有遵守。 這有一份高級開發(fā)人員經常遵循的 19 條原則,其中很多與實際編碼無關,而是與流程以及如何處理任務有關,可能對你有幫助。
這是一條代碼重構的經驗法則,用于決定何時將復制的代碼段替換為新的代碼 / 過程 / 方法。 它的含義是,第一次用到某個功能時,你寫一個特定的解決方法;第二次又用到的時候,你拷貝上一次的代碼;第三次出現的時候,你要著手「抽象化」,寫出通用的解決方法。 該原則的主要思想是使代碼 / 過程 / 方法更加通用,從而保證在其他地方可以重復使用。 應用程序結構與編碼方式保持一致有助于提高其可讀性和可維護性。 嘗試制定編碼標準,這有助于保持編碼一致性。編碼標準應該與變量的命名規(guī)則一樣少。另一大問題是應用程序的結構,開發(fā)人員進行更改或添加新內容的地方應該很明顯。 if 里面嵌套 if 會使得程序很混亂,代碼很難讀。在編寫代碼時可能無法繞開這些問題,但你需要經常查看代碼結構。 一種有效的解決方法是衛(wèi)語句:衛(wèi)語句把復雜的條件表達式拆分成多個條件表達式。 if (account != null)
{
if (order != null)
{
if (order.term == Term.Annually)
{
// term annually
}
else if (order.term == Term.Monthly)
{
// term monthly
}
else
{
throw new InvalidEnumArgumentException(nameof(term));
}
}
else
{
throw new ArgumentNullException(nameof(subscription));
}
}
if (account == null)
{
throw new ArgumentNullException(nameof(account));
}
if (order == null)
{
throw new ArgumentNullException(nameof(order));
}
if (order.term == Term.Annually)
{
// term annually (return here)
}
if (order.term == Term.Monthly)
{
// term monthly (return here)
}
throw new InvalidEnumArgumentException(nameof(order.term));
了解全局有助處理較小的細節(jié)。一旦了解了全局,你就不會花很長的時間在小細節(jié)上。 在編程中進行命名是最困難的事情之一,包括為一個類、一個方法命名,甚至是為變量命名。優(yōu)秀的開發(fā)人員會花時間考慮相關的命名方式,這樣會增加程序的可讀性。 技術負債指開發(fā)人員為了加速軟件開發(fā),在應該采用最佳方案時進行了妥協,改用了短期內能加速軟件開發(fā)的方案,從而在未來給自己帶來的額外開發(fā)負擔。這種技術上的選擇就像一筆債務一樣,雖然眼前看起來可以得到好處,但必須在未來償還。軟件工程師必須付出額外的時間和精力持續(xù)修復之前的妥協所造成的問題及副作用,或是進行重構,把架構改善為最佳實現方式。 對于技術負債問題,提高預估時間有助于解決這類問題。盡自己最大的努力寫好代碼,否則你將不斷地進行代碼完善。 你會看到,高級開發(fā)人員總是給任務預留更多的時間,因為他們知道完成任務所需的時間總是高于預期,而且在評估階段增加一個緩沖時間可以真正幫助你把事情做好。 這確實有助于解決技術負債問題。如果你低估了任務完成時間,你就可能會因為時間不夠而寫出僅僅可以運行的代碼,簡潔性、可維護性就顧不上了。 文檔和代碼注釋有助于保存上下文和共享知識。你會聽到有經驗的人一直在說,我們是否可以記錄這個過程,或者代碼審查失敗,因為對接口之類的內容沒有任何注釋。 許多缺乏自信的開發(fā)人員會注釋掉大量的代碼塊,而不是選擇刪除。但是代碼版本控制是有目的的!優(yōu)秀的開發(fā)人員會刪除應用程序中不好的代碼。 優(yōu)秀的開發(fā)人員會花更多的時間在代碼評審上,代碼評審的重要性包括: 對于一個風險較小的任務,1 名開發(fā)人員評審就可以; 中型 / 大型更改或者是有風險的更改,應由 3 名開發(fā)人員進行評審,其中須有一位是高級開發(fā)人員; 風險極高的更改或者是正在開發(fā)的應用程序的新部分,應該安排一次會議,3 名開發(fā)人員中至少有一位是首席開發(fā)人員,他們一起完成每條線并提出觀點。 你會注意到經驗豐富、能力更強的開發(fā)人員花更多的時間編寫好的測試。擁有好的測試可以幫助你更有信心地擴展應用程序,并減少錯誤。 在真正投入寫代碼之前,開發(fā)者會經過一番思考并將代碼分解成小塊。這有助于他們更好地將所有內容組合在一起并創(chuàng)建更清晰的代碼。 更多地關注基礎原理,而不是語法,有助于開發(fā)者更快地發(fā)現問題,也能更好地理解問題并在搜索引擎上搜索解決方案。 高級開發(fā)者都是用搜索引擎來解決問題的專家。從上一條也可以看出,他們關注基礎原理而不是語法,因此知道要搜索的關鍵詞。如果你一直專注于語法,這將很難做到。 你經常會看到一些相對較弱的開發(fā)人員,他們一開始花費大量的時間讓程序看起來漂亮,但之后發(fā)現,程序不能運行。 優(yōu)秀的開發(fā)人員會在更早的階段找到愉快的工作方式。在他們把事情做好之前,盡早發(fā)現問題。這可以幫助項目進行得更加順利。 高級開發(fā)人員可以定義風險,能夠通過應用設計模式提煉出復雜的問題,并且能夠根據以往的經驗獨立解決不同的問題。 高級開發(fā)人員什么都想知道。他們不介意問問題,包括技術問題和業(yè)務問題,盡管這些問題聽起來非常簡單。理解業(yè)務需求有助于開發(fā)者編寫更好的代碼!他們不害怕問問題,因為他們對自己的能力有信心。 這一點可以歸結為你正在構建的應用程序的類型,并且僅當它不會影響性能時才適用。 高級開發(fā)人員知道將數據庫查詢保留為簡單的 CRUD 操作。CRUD 是指在做計算處理時的增加 (Create)、檢索(Retrieve)、更新(Update) 和刪除(Delete)。 接下來,業(yè)務邏輯層應將 CRUD 操作整合在一起。這有助于開發(fā)人員了解在哪里尋找業(yè)務邏輯。如果你在數據庫查詢和代碼中有邏輯,這會很快變得混亂! 保持代碼簡潔是最好的做法。即使這意味著要編寫更多行代碼。下面是相對較弱的開發(fā)人員編寫的單行代碼: return dir.Keys.Any(k =>k >= limit) ? dir.First(x =>x.Key >= limit).Value : dir[dir.Keys.Max()];
https://medium.com/javascript-in-plain-english/19-things-i-stole-from-great-developers-85511ff56570
|?整理轉載文章為傳播相關技術,版權歸原作者所有?|
|?如有侵權,請聯系刪除?|
免責聲明:本文內容由21ic獲得授權后發(fā)布,版權歸原作者所有,本平臺僅提供信息存儲服務。文章僅代表作者個人觀點,不代表本平臺立場,如有問題,請聯系我們,謝謝!