當前位置:首頁 > 單片機 > 單片機
[導讀]  為了提高源程序的質(zhì)量和可維護性,從而最終提高軟件產(chǎn)品生產(chǎn)力,特編寫此規(guī)范。本標準規(guī)定了程序設(shè)計人員進行程序設(shè)計時必須遵循的規(guī)范。本規(guī)范主要針對單片機編程語言和08編譯器而言,包括排版、注釋、命名、變

  為了提高源程序的質(zhì)量和可維護性,從而最終提高軟件產(chǎn)品生產(chǎn)力,特編寫此規(guī)范。本標準規(guī)定了程序設(shè)計人員進行程序設(shè)計時必須遵循的規(guī)范。本規(guī)范主要針對單片機編程語言和08編譯器而言,包括排版、注釋、命名、變量使用、代碼可測性、程序效率、質(zhì)量保證等內(nèi)容。

1.基本規(guī)則

  格式清晰、注釋簡明扼要、命名規(guī)范易懂、函數(shù)模塊化、程序易讀易維護、功能準確實現(xiàn)、代碼空間效率和時間效率高、適度的可擴展性、單片機編程規(guī)范-標識符命名。

2.標識符命名

  2.1命名基本原則

 ?。?)命名清晰明了,有明確含義,使用完整單詞或約定俗成的縮寫。通常,較短的單詞可通過去掉元音字母形成縮寫;較長的單詞可取單詞的頭幾個字母形成縮寫。即"見名知意"。

  (2)命名風格要自始至終保持一致。

  (3)命名中若使用特殊約定或縮寫,要有注釋說明。

 ?。?)同一軟件產(chǎn)品內(nèi)模塊之間接口部分的標識符名稱之前加上模塊標識。

 2.2宏和常量命名

  宏和常量用全部大寫字母來命名,詞與詞之間用下劃線分隔。對程序中用到的數(shù)字均應(yīng)用有意義的枚舉或宏來代替。

 2.3變量命名

  變量名用小寫字母命名,每個詞的第一個字母大寫。類型前綴(u8s8 etc.)全局變量另加前綴g_。

  局部變量應(yīng)簡明扼要。局部循環(huán)體控制變量優(yōu)先使用i、j、k等;局部長度變量優(yōu)先使用len、num等;臨時中間變量優(yōu)先使用temp、tmp等。

 2.4函數(shù)命名

  函數(shù)名用小寫字母命名,每個詞的第一個字母大寫,并將模塊標識加在最前面。

 2.5文件命名

  一個文件包含一類功能或一個模塊的所有函數(shù),文件名稱應(yīng)清楚表明其功能或性質(zhì)。每個.c文件應(yīng)該有一個同名的.h文件作為頭文件。

3.注釋

 3.1注釋基本原則

  有助于對程序的閱讀理解,說明程序在"做什么",解釋代碼的目的、功能和采用的方法。一般情況源程序有效注釋量在30%左右。注釋語言必須準確、易懂、簡潔。邊寫代碼邊注釋,修改代碼同時修改相應(yīng)的注釋,不再有用的注釋要刪除。匯編和C中都用"http://",取消";"不使用段注釋" /**/ "(調(diào)試時可用)

 3.2文件注釋

  文件注釋必須說明文件名、函數(shù)功能、創(chuàng)建人、創(chuàng)建日期、版本信息等相關(guān)信息。修改文件代碼時,應(yīng)在文件注釋中記錄修改日期、修改人員,并簡要說明此次修改的目的。所有修改記錄必須保持完整。文件注釋放在文件頂端,用"/*……*/"格式包含。注釋文本每行縮進4個空格;每個注釋文本分項名稱應(yīng)對齊。

/***********************************************************

文件名稱:

作者:

版本:

說明:

修改記錄:

***********************************************************/

3.3函數(shù)注釋

3.3.1函數(shù)頭部注釋

  函數(shù)頭部注釋應(yīng)包括函數(shù)名稱、函數(shù)功能、入口參數(shù)、出口參數(shù)等內(nèi)容。如有必要還可增加作者、創(chuàng)建日期、修改記錄(備注)等相關(guān)項目。函數(shù)頭部注釋放在每個函數(shù)的頂端,用"/*……*/"的格式包含。其中函數(shù)名稱應(yīng)簡寫為Name(),不加入、出口參數(shù)等信息。

/***********************************************************

函數(shù)名稱:

函數(shù)功能:

入口參數(shù):

出口參數(shù):

備注:

***********************************************************/

3.3.2代碼注釋

代碼注釋應(yīng)與被注釋的代碼緊鄰,放在其上方或右方,不可放在下面。如放于上方則需與其上面的代碼用空行隔開。一般少量注釋應(yīng)該添加在被注釋語句的行尾,一個函數(shù)內(nèi)的多個注釋左對齊;較多注釋則應(yīng)加在上方且注釋行與被注釋的語句左對齊。函數(shù)代碼注釋用"http://…//"的格式。

通常,分支語句(條件分支、循環(huán)語句等)必須編寫注釋。其程序塊結(jié)束行"}"的右方應(yīng)加表明該程序塊結(jié)束的標記"end of……",尤其在多重嵌套時。

3.4變量、常量、宏的注釋

同一類型的標識符應(yīng)集中定義,并在定義之前一行對其共性加以統(tǒng)一注釋。對單個標識符的注釋加在定義語句的行尾。全局變量一定要有詳細的注釋,包括其功能、取值范圍、哪些函數(shù)或過程存取它以及存取時的注意事項等。注釋用"http://…//"的格式。

4.函數(shù)

4.1函數(shù)設(shè)計原則

函數(shù)的基本要求:

    1)封裝性

    1)正確性:程序要實現(xiàn)設(shè)計要求的功能。

    2)穩(wěn)定性和安全性:程序運行穩(wěn)定、可靠、安全。

    3)可測試性:程序便于測試和評價。

    4)規(guī)范/可讀性:程序書寫風格、命名規(guī)則等符合規(guī)范。

    5)擴展性:代碼為下一次升級擴展留有空間和接口。

    6)全局效率:軟件系統(tǒng)的整體效率高。

    7)局部效率:某個模塊/子模塊/函數(shù)的本身效率高。

編制函數(shù)的基本原則:

    1)單個函數(shù)的規(guī)模盡量限制在200行以內(nèi)(不包括注釋和空行)。一個函數(shù)只完成一個功能。

    2)函數(shù)局部變量的數(shù)目一般不超過5~10個。

    3)函數(shù)內(nèi)部局部變量定義區(qū)和功能實現(xiàn)區(qū)(包含變量初始化)之間空一行。

    4)函數(shù)名應(yīng)準確描述函數(shù)的功能。通常使用動賓詞組為執(zhí)行某操作的函數(shù)命名。

    5)函數(shù)的返回值要清楚明了,尤其是出錯返回值的意義要準確無誤。

    6)不要把與函數(shù)返回值類型不同的變量,以編譯系統(tǒng)默認的轉(zhuǎn)換方式或強制的轉(zhuǎn)換方式作為返回值返回。

    7)減少函數(shù)本身或函數(shù)間的遞歸調(diào)用。

    8)盡量不要將函數(shù)的參數(shù)作為工作變量。

4.2函數(shù)定義

    1)函數(shù)若沒有入口參數(shù)或者出口參數(shù),應(yīng)用void明確申明。

    2)函數(shù)名稱與出口參數(shù)類型定義間應(yīng)該空一格且只空一格。

    3)函數(shù)名稱與括號()之間無空格。

    4)函數(shù)形參必須給出明確的類型定義。

    5)多個形參的函數(shù),后一個形參與前一個形參的逗號分割符之間添加一個空格。

    6)函數(shù)體的前后花括號"{}"各獨占一行。

4.3局部變量定義

    1)同一行內(nèi)不要定義過多變量。

    2)同一類的變量在同一行內(nèi)定義,或者在相鄰行定義。

    3)先定義data型變量,再定義idtata型變量,再定義xdata型變量.(?)

    4)數(shù)組、指針等復雜類型的定義放在定義區(qū)的最后。

    5)變量定義區(qū)不做較復雜的變量賦值。

4.4功能實現(xiàn)區(qū)規(guī)范

    1)一行只寫一條語句。

    2)注意運算符的優(yōu)先級,并用括號明確表達式的操作順序,避免使用默認優(yōu)先級。

    3)各程序段之間使用一個空行分隔,加以必要的注釋。程序段指能完一個較具體的功能的一行或多行代碼。程序段內(nèi)的各行代碼之間相互依賴性較強。(1、2、3方式)

    4)不要使用難懂的技巧性很高的語句。

    5)源程序中關(guān)系較為緊密的代碼應(yīng)盡可能相鄰。

    6)完成簡單功能、關(guān)系非常密切的一條或幾條語句可編寫為函數(shù)或定義為宏。

5.單片機編程規(guī)范-排版

  5.1縮進

    代碼的每一級均往右縮進4個空格的位置。不使用Tab鍵

  5.2分行

    每行語句(?????超過80個字符)要分成多行書寫;長表達式要在低優(yōu)先級操作符處劃分新行,操作符放在新行之首,劃分出的新行要進適當?shù)目s進,使排版整齊,語句可讀。避免把注釋插入分行中。

5.3空行

    1)文件注釋區(qū)、頭文件引用區(qū)、函數(shù)間應(yīng)該有且只有一行空行。

    2)相鄰函數(shù)之間應(yīng)該有且只有一行空行。

    3)函數(shù)體內(nèi)相對獨立的程序塊之間可以用一行空行或注釋來分隔。

    4)函數(shù)注釋和對應(yīng)的函數(shù)體之間不應(yīng)該有空行。

    5)文件末尾有且只有一行空行。

5.4空格

    1)函數(shù)語句尾部或者注釋之后不能有空格。

    2)括號內(nèi)側(cè)(即左括號后面和右括號前面)不加空格,多重括號間不加空格。

    3)函數(shù)形參之間應(yīng)該有且只有一個空格(形參逗號后面加空格)。

    4)同一行中定義的多個變量間應(yīng)該有且只有一個空格(變量逗號后面加空格)。

    5)表達式中,若有多個操作符連寫的情況,應(yīng)使用空格對它們分隔:

    6)在兩個以上的關(guān)鍵字、變量、常量進行對等操作時,它們之間的操作符前后均加一個空格;在兩個以上的關(guān)鍵字、變量、常量進行非對等操作時,其前后均不應(yīng)加空格;

    7)逗號只在后面加空格;

    8)雙目操作符,如比較操作符,賦值操作符"="、"+=",算術(shù)操作符"+"、"%",邏輯操作符"&&"、"&",位操作符"<<"、"^"等,前后均加一個空格;

    9)單目操作符,如"!"、"~"、"++"、"-"、"&"(地址運算符)等,前后不加空格;

    10) "->"、"."前后不加空格;

    11) if、for、while、switch等關(guān)鍵字與后面的括號間加一個空格;

5.5花括號

    1)if、else if、else、for、while語句無論其執(zhí)行體是一條語句還是多條語句都必須加花括號,且左右花括號各獨占一行。

2) do{}while()結(jié)構(gòu)中,"do"和"{"均各占一行,"}"和"while();"共同占用一行。

本站聲明: 本文章由作者或相關(guān)機構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫毥谦F公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運行,同時企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風險,如企業(yè)系統(tǒng)復雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機 衛(wèi)星通信

要點: 有效應(yīng)對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅持高質(zhì)量發(fā)展策略,塑強核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運營商 數(shù)字經(jīng)濟

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術(shù)學會聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(shù)(集團)股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉