加入星計劃,您可以享受以下權(quán)益:

  • 創(chuàng)作內(nèi)容快速變現(xiàn)
  • 行業(yè)影響力擴散
  • 作品版權(quán)保護
  • 300W+ 專業(yè)用戶
  • 1.5W+ 優(yōu)質(zhì)創(chuàng)作者
  • 5000+ 長期合作伙伴
立即加入
  • 正文
  • 相關(guān)推薦
  • 電子產(chǎn)業(yè)圖譜
申請入駐 產(chǎn)業(yè)圖譜

有哪些不推薦使用的嵌入式 C 語言語法特性?

11/22 10:40
564
閱讀需 5 分鐘
加入交流群
掃碼加入
獲取工程師必備禮包
參與熱點資訊討論

我是老溫,一名熱愛學(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ì)量和可維護性。

相關(guān)推薦

電子產(chǎn)業(yè)圖譜