造成這種情況的一個原因是,雖然初始編碼可能進展迅速,但調(diào)試周期似乎是無休止的。以后,代碼的維護是不可避免的,而且需要比預期更多的時間。這是因為在嘗試修改之前準確理解代碼的功能會產(chǎn)生開銷。
這一觀察的結(jié)果是,應(yīng)高度重視代碼的可讀性。易于閱讀的代碼不太可能出現(xiàn)錯誤,因此減少了調(diào)試時間。如果代碼易于理解,則更易于維護。因此,請始終牢記人類讀者——畢竟,它可能是你。(我聽說它建議你假設(shè)你的代碼未來的維護者是一個知道你家庭地址的精神病患者。)
代碼由兩部分組成:編譯器需要看到的東西(C 語句和聲明)和需要對編譯器隱藏的文本(主要是供人類讀者使用的)。隱藏的東西主要是:
文檔——代碼中的注釋
暫時刪除的代碼——調(diào)試過程中不可避免的一部分
調(diào)試/跟蹤代碼——可以根據(jù)需要打開和關(guān)閉
有趣的是,如果您取出純粹為人類讀者閱讀的內(nèi)容(其中還包括使用有意義的標識符和額外的空格,如換行符),結(jié)果是完全不可讀的代碼。一些軟件公司利用這一點來分發(fā)源代碼,同時保護他們的知識產(chǎn)權(quán)。
我將看看我們對編譯器隱藏的東西。
文檔
每個人都知道評論是個好主意,但我們都很懶惰。然而,這種努力是值得的。舊式/* 。.. */ C注釋還可以,但我覺得 C++ 行尾[ //。.. ]的變化更清晰。它們?nèi)匀恍枰⌒氖褂?。例如,像這樣的代碼:
并且不要使用標簽。它們不是便攜式的。
臨時代碼刪除
在調(diào)試和測試代碼的過程中,能夠暫時“關(guān)閉”一段代碼通常很有用。許多程序員通過將/*放在開頭,將*/放在結(jié)尾來“注釋掉”代碼以實現(xiàn)此結(jié)果。這是快速而骯臟的,但經(jīng)常無法達到所需的結(jié)果。許多編譯器不支持嵌套注釋,因此,如果代碼已經(jīng)被注釋,就會出現(xiàn)問題。總的來說,它容易出錯,應(yīng)該避免。
使用 C++ 風格的//注釋符號——即,將//放在每行的開頭——稍微好一點,但應(yīng)用起來非常乏味,而且在刪除時也可能容易出錯。
實現(xiàn)此結(jié)果的最佳方法是使用預處理器指令,因此:
在任何情況下,“關(guān)閉”的代碼序列都不應(yīng)包含在任何正在考慮發(fā)布的代碼中。
調(diào)試/跟蹤代碼
另一種臨時代碼是為了便于在調(diào)試時輸出或記錄額外信息而包含的。盡管現(xiàn)代調(diào)試器和此類工具可能非常有效,但有時檢測代碼仍然是弄清楚到底發(fā)生了什么的最佳方式?,F(xiàn)代開發(fā)工具是如此之快,以至于重建以創(chuàng)建啟用調(diào)試的映像并不是一個嚴重的開銷。
促進這一點的常用方法是使用預處理器指令,因此:
因此,當定義符號DEBUG_TRACE時,將包含調(diào)試代碼。
一個稍微不同的方法是這樣編碼:
這個雙重否定看起來很笨拙,但是這個符號用于控制標準的assert()宏。程序員需要定義符號來抑制調(diào)試模式。
審核編輯:郭婷
-
C++
+關(guān)注
關(guān)注
22文章
2119瀏覽量
75349 -
代碼
+關(guān)注
關(guān)注
30文章
4900瀏覽量
70786 -
編譯器
+關(guān)注
關(guān)注
1文章
1662瀏覽量
50241
發(fā)布評論請先 登錄
泰克示波器 MSO58 混合信號示波器在嵌入式系統(tǒng)調(diào)試中的核心技巧

普源示波器MSO5074在嵌入式系統(tǒng)聯(lián)合調(diào)試中的高效實踐

Python在嵌入式系統(tǒng)中的應(yīng)用場景
泰克MDO32示波器在嵌入式系統(tǒng)調(diào)試中的關(guān)鍵技術(shù)分析

嵌入式系統(tǒng)中的代碼優(yōu)化與壓縮技術(shù)
如何提高嵌入式代碼質(zhì)量?
MPU在嵌入式系統(tǒng)中的應(yīng)用
嵌入式系統(tǒng)開發(fā)與硬件的關(guān)系 嵌入式系統(tǒng)開發(fā)常見問題解決
HAL庫在嵌入式系統(tǒng)中的應(yīng)用
mmc卡在嵌入式系統(tǒng)中的使用
PROM器件在嵌入式系統(tǒng)中的應(yīng)用
使用高級事件觸發(fā)調(diào)試高速嵌入式微處理器系統(tǒng)中的實時問題

評論