91欧美超碰AV自拍|国产成年人性爱视频免费看|亚洲 日韩 欧美一厂二区入|人人看人人爽人人操aV|丝袜美腿视频一区二区在线看|人人操人人爽人人爱|婷婷五月天超碰|97色色欧美亚州A√|另类A√无码精品一级av|欧美特级日韩特级

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

C++代碼需要遵循的10個最佳實踐

CPP開發(fā)者 ? 來源:DeepNoMind ? 作者:俞凡 ? 2022-10-18 15:20 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

C++代碼提供了足夠的靈活性,因此對于大部分工程師來說都很難把握。本文介紹了寫好C++代碼需要遵循的10個最佳實踐,并在最后提供了一個工具可以幫助我們分析C++代碼的健壯度。

1. 盡可能嘗試使用新的C++標(biāo)準(zhǔn)

到2022年,C++已經(jīng)走過了40多個年頭。新的C++標(biāo)準(zhǔn)實際上簡化了許多令人沮喪的細(xì)節(jié),提供了新的現(xiàn)代方法來改進(jìn)C++代碼,但讓開發(fā)人員認(rèn)識到這一點并不容易。

以內(nèi)存管理為例,這可能是C++中受到最多批評的機制。多年來,對象分配都是由new關(guān)鍵字完成的,開發(fā)人員一定得記住在代碼的某個地方調(diào)用delete?!艾F(xiàn)代C++”解決了這個問題,并促進(jìn)了共享指針的使用。

2. 使用命名空間模塊化代碼

現(xiàn)代C++庫廣泛使用命名空間來模塊化代碼庫,它們利用“Namespace-by-feature”方法,按功能劃分命名空間來反映功能集,將單個特性(且僅與該特性)相關(guān)的所有內(nèi)容放到單個命名空間中。從而使得命名空間具有高內(nèi)聚性和高模塊化,并且耦合最小,緊耦合的項目被放在了一起。

Boost是按特性分組的最佳示例,其包含數(shù)千個命名空間,每個命名空間用于對特定的特性進(jìn)行分組。

3. 抽象

數(shù)據(jù)抽象是C++中面向?qū)ο?a target="_blank">編程最基本和最重要的特性之一。抽象意味著只顯示基本信息而隱藏細(xì)節(jié),數(shù)據(jù)抽象指的是僅向外部世界提供關(guān)于數(shù)據(jù)的基本信息,隱藏背景細(xì)節(jié)或?qū)崿F(xiàn)。

盡管許多書籍、網(wǎng)絡(luò)資源、會議演講者和專家都推薦這種最佳實踐,但在很多項目中,這條規(guī)則仍然被忽略了,許多類的細(xì)節(jié)并沒有被隱藏。

4. 類越小越好

具有多行代碼的類型應(yīng)該被劃分為一組較小的類型。

需要很大的耐心重構(gòu)一個大的類,甚至可能需要從頭重新創(chuàng)建所有東西。以下是一些重構(gòu)建議:

BigClass中的邏輯必須被分成更小的類。這些較小的類最終可能成為嵌套在原始God Class中的私有類,God Class的實例對象由較小嵌套類的實例組成。

較小的類劃分應(yīng)該由God Class負(fù)責(zé)的多個職責(zé)驅(qū)動。要確定這些職責(zé),通常需要查找與字段的子集強耦合的方法的子集。

如果BigClass包含的邏輯比狀態(tài)多,一個好的選擇是定義一個或幾個不包含靜態(tài)字段而只包含純靜態(tài)方法的靜態(tài)類。純靜態(tài)方法是一種只根據(jù)輸入?yún)?shù)計算結(jié)果的函數(shù),它不讀取或分配任何靜態(tài)或?qū)嵗侄巍<冹o態(tài)方法的主要優(yōu)點是易于測試。

首先嘗試維護BigClass的接口,并委托調(diào)用新提取的類。最后,BigClass應(yīng)該是一個沒有自己邏輯的純接口,可以為了方便將其保留,也可以將其扔掉,并開始只使用新類。

單元測試可以提供幫助: 在提取方法之前為每個方法編寫測試,以確保不會破壞功能。

5. 每個類盡量提供最少的方法

包含20個以上方法的類可能很難理解和維護。

一個類有許多方法可能是實現(xiàn)了太多責(zé)任的癥狀。

也許所面對的類控制了系統(tǒng)中太多的其他類,并且已經(jīng)超出了應(yīng)有的邏輯,成為了一個無所不能的類。

6. 加強低耦合

低耦合是理想狀態(tài),可以在應(yīng)用中進(jìn)行較少的更改實現(xiàn)程序的某個變更。從長遠(yuǎn)來看,可以減少修改、添加新特性的大量時間、精力和成本。

低耦合可以通過使用抽象類或泛型類和方法來實現(xiàn)。

7. 加強高內(nèi)聚

單一責(zé)任原則規(guī)定一個類不應(yīng)該有多于一個更改的理由,這樣的類被稱為內(nèi)聚類。較高的LCOM值通??梢砸馕吨惖膬?nèi)聚性較差。有幾個LCOM指標(biāo),取值范圍為[0-1]。LCOM HS (HS代表Henderson-Sellers)取值范圍為[0-2]。LCOM HS值大于1時需要產(chǎn)生警惕。下面是計算LCOM指標(biāo):

LCOM = 1 — (sum(MF)/M*F)
LCOM HS = (M — sum(MF)/F)(M-1)

其中……

M是類中方法的數(shù)量(包括靜態(tài)方法和實例方法,它還包括構(gòu)造函數(shù)、屬性getter/setter、事件添加/刪除方法)。

F是類中實例字段的數(shù)量。

MF是類訪問特定實例字段的方法數(shù)量。

Sum(MF)是該類所有實例字段的MF之和。

這些公式背后的基本思想可以表述如下: 如果一個類的所有方法都使用它的所有實例字段,那么這個類就是完全內(nèi)聚的,這意味著sum(MF)=M*F,然后LCOM = 0和LCOMHS = 0。

LCOMHS值大于1就需要警惕了。

8. 只注釋代碼不能表達(dá)的內(nèi)容

鸚鵡學(xué)舌的代碼注釋沒有為讀者提供任何額外的東西。代碼庫中充斥著嘈雜的注釋和不正確的注釋,促使程序員忽略所有的注釋,或者采取積極的措施隱藏它們。

9. 盡量不要用重復(fù)的代碼

眾所周知,重復(fù)代碼的存在對軟件開發(fā)和維護有負(fù)面影響。實際上,一個主要缺點是,當(dāng)為了修復(fù)bug或添加新特性而更改重復(fù)代碼的實例時,所有對應(yīng)的代碼必須同時更改。

產(chǎn)生重復(fù)代碼最常見的原因是復(fù)制/粘貼操作,這種情況下,相似的源代碼出現(xiàn)在兩個或多個地方。許多文章、書籍和網(wǎng)站都警告不要采用這種做法,但有時實踐這些建議并不容易,開發(fā)人員還是會選擇簡單的解決方案: 復(fù)制/粘貼大法。

使用適當(dāng)?shù)墓ぞ呖梢匀菀椎膹膹?fù)制/粘貼操作中檢測到重復(fù)代碼,但是,在某些情況下,克隆代碼很難被檢測到。

10. 不變性有助于多線程編程

基本上,如果對象在創(chuàng)建之后狀態(tài)不變,那么這個對象就是不可變(immutable)的。如果一個類的實例是不可變的,那么該類就是不可變的。

不可變對象極大簡化了并發(fā)編程,這是支持使用它的重要理由。想想看,為什么編寫適當(dāng)?shù)亩嗑€程程序是一項艱巨的任務(wù)?因為同步線程訪問資源(對象或其他操作系統(tǒng)資源)是很困難的。為什么同步這些訪問很困難?因為很難保證多個線程對多個對象進(jìn)行的多次寫訪問和讀訪問之間不會出現(xiàn)競爭條件。如果不再有寫訪問會怎么樣?換句話說,如果被線程訪問的對象的狀態(tài)沒有改變會怎么樣?就不再需要同步了!

關(guān)于不可變類的另一個好處是它們永遠(yuǎn)不會違反里氏替換原則(LSP, Liskov Subtitution Principle),以下是維基百科對LSP的定義:

Liskov的行為子類型的概念定義了可變對象可替換性的概念,也就是說,如果S是T的子類型,那么程序中T類型的對象可以被替換為S類型的對象,而不改變該程序的任何期望屬性(例如,正確性)。

如果沒有公共字段,沒有可以更改其內(nèi)部數(shù)據(jù)的方法,并且派生類方法無法更改其內(nèi)部數(shù)據(jù),那么引用對象類就是不可變的。因為值不可變,所以在所有情況下都可以引用相同的對象,不需要復(fù)制構(gòu)造函數(shù)或賦值操作符。出于這個原因,建議將復(fù)制構(gòu)造函數(shù)和賦值操作符設(shè)為私有,或者從boost::noncopyable繼承,或者使用新的C++ 11特性“顯式默認(rèn)和刪除特殊成員函數(shù)”[2]。

如何加強對這些最佳實踐進(jìn)行檢查?

CppDepend[3]提供了名為CQLinq[4]的代碼查詢語言,可以像數(shù)據(jù)庫一樣查詢代碼庫。開發(fā)人員、設(shè)計人員和架構(gòu)師可以自定義查詢,以便輕松找到容易出現(xiàn)bug的情況。

通過CQLinq,可以結(jié)合來自代碼度量、依賴關(guān)系、API使用和其他模型的數(shù)據(jù)來定義非常高級的查詢,以匹配容易出現(xiàn)bug的情況。

例如,分析clang源代碼后,可以檢測到大類:

873f83c0-4e99-11ed-a3b6-dac502259ad0.png

檢測到有大量方法的類:

876b6bac-4e99-11ed-a3b6-dac502259ad0.png

或者檢測到內(nèi)聚性較差的類:

8802c402-4e99-11ed-a3b6-dac502259ad0.png

審核編輯:郭婷


聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • C++
    C++
    +關(guān)注

    關(guān)注

    22

    文章

    2123

    瀏覽量

    77110
  • 代碼
    +關(guān)注

    關(guān)注

    30

    文章

    4967

    瀏覽量

    73954
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

    keil實現(xiàn)cc++混合編程

    參考touchgfx生成的代碼,發(fā)現(xiàn)了一需要添加--cpp11 參數(shù)的解決方法,具體操作如下。 一、創(chuàng)建一空白的C文件和頭文件在頭文件
    發(fā)表于 01-26 08:58

    C語言與C++的區(qū)別及聯(lián)系

    缺點:性能比面向過程低。 二、具體語言上的區(qū)別 1、關(guān)鍵字的不同 C語言有32關(guān)鍵字;C++有63關(guān)鍵字。 2、后綴名不同 C
    發(fā)表于 12-24 07:23

    BMS設(shè)計中如何選擇MOSFET——關(guān)鍵考慮因素與最佳實踐

    MOSFET時需要綜合考慮多個因素,以確保其滿足BMS的高效和穩(wěn)定運行要求。本文將介紹在BMS設(shè)計過程中選擇MDD的MOSFET時需要重點關(guān)注的關(guān)鍵因素和最佳實踐。一、MO
    的頭像 發(fā)表于 12-15 10:24 ?422次閱讀
    BMS設(shè)計中如何選擇MOSFET——關(guān)鍵考慮因素與<b class='flag-5'>最佳</b><b class='flag-5'>實踐</b>

    CC++之間的聯(lián)系

    且不需要高級特性的場景,而C++則在提供高效性能的同時,還能借助面向?qū)ο蠛头盒途幊痰忍匦蕴岣哕浖目删S護性和可擴展性
    發(fā)表于 12-11 06:51

    C語言和C++之間的區(qū)別是什么

    C++的標(biāo)準(zhǔn)庫那樣集成度高和功能齊全。 6、編譯器與語言特性: C++編譯器通常比C語言編譯器更加復(fù)雜,因為它需要處理更多的語言特性,比如模板元編程、命名空間、引用等。
    發(fā)表于 12-11 06:23

    C/C++條件編譯

    條件編譯是一種在編譯時根據(jù)條件選擇性地包含或排除部分代碼的處理方法。在 C/C++ 中,條件編譯使用預(yù)處理指令 #ifdef、#endif、#else 和 #elif 來實現(xiàn)。常用的條件編譯指令有
    發(fā)表于 12-05 06:21

    C++程序異常的處理機制

    運行代碼進(jìn)行分離,使得程序更加模塊化;另一方面,C++的異常處理可以不需要異常處理在異常發(fā)生時的同一函數(shù),而是可以在更上層合適的位置進(jìn)行處理。 下面,我們一起來看看
    發(fā)表于 12-02 07:12

    立訊精密榮獲2025年上市公司可持續(xù)發(fā)展最佳實踐案例

    11月18日,由中國上市公司協(xié)會(中上協(xié))主辦的2025上市公司可持續(xù)發(fā)展大會在北京隆重召開。會上,中上協(xié)發(fā)布了2025上市公司可持續(xù)發(fā)展最佳實踐案例名單,從環(huán)境、社會和治理3維度出發(fā)評優(yōu)樹典,立
    的頭像 發(fā)表于 11-26 17:49 ?1752次閱讀

    嵌入式C/C++回歸測試四大最佳實踐(附自動化測試工具TESSY使用教程)

    嵌入式開發(fā)中,一次微小的代碼改動都可能引發(fā)“蝴蝶效應(yīng)”,如何守護系統(tǒng)的穩(wěn)???推薦專業(yè)的自動化測試工具#TESSY,源自戴姆勒-奔馳,是嵌入式C/C++單元/集成測試的標(biāo)桿。
    的頭像 發(fā)表于 10-31 14:21 ?405次閱讀
    嵌入式<b class='flag-5'>C</b>/<b class='flag-5'>C++</b>回歸測試四大<b class='flag-5'>最佳</b><b class='flag-5'>實踐</b>(附自動化測試工具TESSY使用教程)

    C/C++代碼靜態(tài)測試工具Perforce QAC 2025.3的新特性

    ?Perforce Validate?中?QAC?項目的相對/根路徑的支持。C++?分析也得到了增強,增加了用于檢測 C++?并發(fā)問題的新檢查,并改進(jìn)了實體名稱和實
    的頭像 發(fā)表于 10-13 18:11 ?568次閱讀
    <b class='flag-5'>C</b>/<b class='flag-5'>C++</b><b class='flag-5'>代碼</b>靜態(tài)測試工具Perforce QAC 2025.3的新特性

    Perforce QAC產(chǎn)品簡介:面向C/C++的靜態(tài)代碼分析工具(已通過SO 26262認(rèn)證)

    Perforce QAC專為C/C++開發(fā)者打造,支持多種編碼規(guī)范、功能安全標(biāo)準(zhǔn)(ISO 26262)等,廣泛用于汽車、醫(yī)療、嵌入式開發(fā)領(lǐng)域,可幫助快速識別關(guān)鍵缺陷、提升代碼質(zhì)量、實現(xiàn)合規(guī)交付。
    的頭像 發(fā)表于 07-10 15:57 ?1262次閱讀
    Perforce QAC產(chǎn)品簡介:面向<b class='flag-5'>C</b>/<b class='flag-5'>C++</b>的靜態(tài)<b class='flag-5'>代碼</b>分析工具(已通過SO 26262認(rèn)證)

    Linux網(wǎng)絡(luò)管理的關(guān)鍵技術(shù)和最佳實踐

    在大型互聯(lián)網(wǎng)企業(yè)中,Linux網(wǎng)絡(luò)管理是運維工程師的核心技能之一。面對海量服務(wù)器、復(fù)雜網(wǎng)絡(luò)拓?fù)洹⒏卟l(fā)流量,運維人員需要掌握從基礎(chǔ)網(wǎng)絡(luò)配置到高級網(wǎng)絡(luò)優(yōu)化的全套技術(shù)棧。本文將結(jié)合大廠實際場景,深入解析Linux網(wǎng)絡(luò)管理的關(guān)鍵技術(shù)和最佳實踐
    的頭像 發(fā)表于 07-09 09:53 ?945次閱讀

    在OpenVINO? C++代碼中啟用 AddressSanitizer 時的內(nèi)存泄漏怎么解決?

    在 OpenVINO? C++代碼中啟用 AddressSanitizer 時遇到內(nèi)存泄漏: \"#0 0xaaaab8558370 in operator new(unsigned
    發(fā)表于 06-23 07:16

    天馬榮獲新財富雜志“2024 ESG最佳實踐獎”

    天馬可持續(xù)發(fā)展?ESG表現(xiàn)再獲認(rèn)可,上榜2024年新財富雜志最佳上市公司評選“ESG最佳實踐榜單”。
    的頭像 發(fā)表于 05-21 14:43 ?936次閱讀

    創(chuàng)建了用于OpenVINO?推理的自定義C++和Python代碼,從C++代碼中獲得的結(jié)果與Python代碼不同是為什么?

    創(chuàng)建了用于OpenVINO?推理的自定義 C++ 和 Python* 代碼。 在兩推理過程中使用相同的圖像和模型。 從 C++ 代碼
    發(fā)表于 03-06 06:22