我是老溫,一名熱愛學(xué)習(xí)的嵌入式工程師。關(guān)注我,一起變得更加優(yōu)秀!
從事嵌入式軟件開發(fā)的工程師朋友都知道,C 語言是一種非常靈活和強大的編程語言,尤其是在操作系統(tǒng)內(nèi)核方面,C 語言更有著舉足輕重的地位。
但是,隨著 C 語言編程實踐的發(fā)展和編程語言的演進,以往經(jīng)常使用的一些 C 語言語法特性,逐漸開始被行業(yè)認(rèn)為,不推薦使用。
主要因為,使用這些語法特性可能會導(dǎo)致代碼可讀性差、可維護性低、安全性問題或者效率低下。
以下是一些不建議使用的 C 語言語法特性:
1. 魔法數(shù)字(Magic Numbers)
直接在代碼中使用具體的數(shù)值,如 if (x == 5) ,而不是定義為常量或枚舉類型。這樣做會導(dǎo)致該段代碼語義含糊,維護該代碼的程序員極有可能不知道該數(shù)字所表達(dá)的含義。
2. 全局變量
過度使用全局變量可能導(dǎo)致代碼難以理解和維護,因為它們可以在程序的任何地方被修改,并且讓各個模塊存在高度的耦合,C 語言軟件規(guī)模越大,越不建議使用全局變量。
嵌入式 C 語言,為什么全局變量越少越好?
3. 宏(Macros)
宏其實很有用,可以幫助程序員借助編譯器的運算能力,在預(yù)處理階段處理一些內(nèi)容,但過量地使用宏定義,可能會導(dǎo)致代碼閱讀性變差,并且可能導(dǎo)致代碼難以調(diào)試和容易出錯,尤其是在宏展開時。
4. 指針運算
直接操作指針進行算術(shù)運算,如 p++ ,效率有時是比較高的,但一定一定要注意在進行指針運算時,指針的運算范圍限定,一不小心使用不當(dāng),極有可能會造成內(nèi)存訪問錯誤。
5. goto語句
goto 語句可以跳轉(zhuǎn)到程序的任意位置,這個跳轉(zhuǎn)可以任意操作并且會忽略一大段邏輯結(jié)構(gòu)代碼,雖然很多錯誤處理都使用goto,但在業(yè)務(wù)邏輯設(shè)計時建議慎用,這會很容易破壞代碼的結(jié)構(gòu)化,使得代碼難以閱讀和維護。
6. 未使用的代碼
代碼中如果存在大量未使用的變量和函數(shù),這可能會導(dǎo)致混淆和不必要的編譯警告,并且會讓后期的代碼維護變得復(fù)雜和困難,建議代碼提交的時候,把不必要的代碼進行注釋屏蔽或者直接刪除。
7. C語言中的布爾類型濫用
很多 C 語言程序員喜歡用整型值 0 和 1 用作布爾值,用數(shù)字 0 表示 false,用數(shù)字 1 表示 true,而不是使用 _Bool 類型,這在以前舊的 C 語言語法里面很常見,但建議還是使用 bool 關(guān)鍵字進行變量定義。
8. 不安全的字符串操作
使用 strcpy 或 strcat 等不安全的字符串函數(shù),這樣可能會導(dǎo)致緩沖區(qū)溢出,因為這類字符串操作函數(shù)不會檢查緩沖區(qū)的大小,它們會直接操作到字符串的 ‘’ 直至結(jié)束。
9. 不檢查函數(shù)返回值
對于返回錯誤信息的函數(shù),不檢查其返回值可能導(dǎo)致程序在遇到錯誤時繼續(xù)執(zhí)行。我們有時候為了省事和方便,會有意無意地忽略函數(shù)或模塊的返回值,但有時候,返回值包含了豐富的函數(shù)執(zhí)行信息。
10. 不使用const關(guān)鍵字
對于不應(yīng)該被修改的變量不使用 const 關(guān)鍵字,這可能導(dǎo)致意外修改和難以發(fā)現(xiàn)的錯誤。在變量傳參或初始化定義時,對于一些不再被修改的變量,建議使用 const 關(guān)鍵字,告訴程序員和編譯器,該變量在使用時不會再被修改。
這些只是一些簡單的舉例,但并不是絕對禁止使用。實際上,是否使用某些語法還應(yīng)該取決于具體的編程環(huán)境和業(yè)務(wù)需求。
有些規(guī)范在當(dāng)時可能是最佳的解決方案,但隨著業(yè)務(wù)和技術(shù)的發(fā)展,更好的替代方案也可能隨之出現(xiàn).
在實際編程中,應(yīng)該盡量遵循最佳的編程實踐和代碼規(guī)范,以提高代碼的質(zhì)量和可維護性。