資源描述:
《c語言格式書寫規(guī)范》由會員上傳分享,免費在線閱讀,更多相關內(nèi)容在教育資源-天天文庫。
1、-C語言書寫規(guī)范指南第1章文件結(jié)構每個C程序通常分為兩個文件。一個文件用于保存程序的聲明(declaration),稱為頭文件。另一個文件用于保存程序的實現(xiàn)(implementation),稱為定義(definition)文件。C程序的頭文件以“.h”為后綴,C程序的定義文件以“.c”為后綴。1.1版權和版本的聲明版權和版本的聲明位于頭文件和定義文件的開頭(參見示例1-1),主要內(nèi)容有:(1)版權信息。(2)文件名稱,標識符,摘要。(3)當前版本號,作者/修改者,完成日期。(4)版本歷史信息。/**Copyright(c)2001,吉林大學物理學院無線
2、電*Allrightsreserved.**文件名稱:filename.h*文件標識:*摘要:簡要描述本文件的內(nèi)容**當前版本:1.1*作者:輸入作者(或修改者)名字*完成日期:2007年7月20日**取代版本:1.0*原作者:輸入原作者(或修改者)名字*完成日期:2007年5月10日*/示例1-1版權和版本的聲明----1.2頭文件的結(jié)構頭文件由三部分內(nèi)容組成:(1)頭文件開頭處的版權和版本聲明(參見示例1-1)。(2)預處理塊。(3)函數(shù)和類結(jié)構聲明等。假設頭文件名稱為SCL_SPI.h,頭文件的結(jié)構參見示例1-2?!疽?guī)則1-2-1】為了防止頭文件
3、被重復引用,應當用#ifndef/#define/#endif結(jié)構產(chǎn)生預處理塊?!疽?guī)則1-2-2】用#include格式來引用標準庫的頭文件(編譯器將從標準庫目錄開始搜索)?!疽?guī)則1-2-3】用#include“filename.h”格式來引用非標準庫的頭文件(編譯器將從用戶的工作目錄開始搜索)?!疽?guī)則1-2-4】#include后面使用TAB鍵控制排版?!疽?guī)則1-2-5】頭文件中只存放“聲明”而不存放“定義”【規(guī)則1-2-6】全局變量在頭文件中聲明,在.c文件中定義.hexternintvalue;聲明。.cintvalue=
4、0x10;定義?!疽?guī)則1-2-7】局部變量在.c中定義(static)unsignedintvalue;定義。//版權和版本聲明見示例1-1,此處省略。#ifndefSCL_SPI_H//防止SCL_SPI.h被重復引用#defineSCL_SPI_H#include//引用標準庫的頭文件…#include“SCL_CAN.h”//引用非標準庫的頭文件…voidFunction1(…);//全局函數(shù)聲明…externunsignintvalue;//全局變量聲明#endif示例1-2C頭文件的結(jié)構----1.3定義文件的結(jié)構定
5、義文件有三部分內(nèi)容:(1)定義文件開頭處的版權和版本聲明(參見示例1-1)。(2)對一些頭文件的引用。(3)程序的實現(xiàn)體(包括數(shù)據(jù)和代碼)。假設定義文件的名稱為SCL_SPI.c,定義文件的結(jié)構參見示例1-3。//版權和版本聲明見示例1-1,此處省略。#include“SCL_SPI.h”//引用頭文件…//全局變量定義unsignintvalue=0x10;//全局函數(shù)的實現(xiàn)體voidFunction1(…){…}示例1-3C定義文件的結(jié)構1.4頭文件的作用早期的編程語言如Basic、Fortran沒有頭文件的概念,C語言的初學者雖然會用使用頭文件,
6、但常常不明其理。這里對頭文件的作用略作解釋:(1)通過頭文件來調(diào)用庫功能。在很多場合,源代碼不便(或不準)向用戶公布,只要向用戶提供頭文件和二進制的庫即可。用戶只需要按照頭文件中的接口聲明來調(diào)用庫功能,而不必關心接口怎么實現(xiàn)的。編譯器會從庫中提取相應的代碼。(2)頭文件能加強類型安全檢查。如果某個接口被實現(xiàn)或被使用時,其方式與頭文件中的聲明不一致,編譯器就會指出錯誤,這一簡單的規(guī)則能大大減輕程序員調(diào)試、改錯的負擔。----1.5目錄結(jié)構如果一個軟件的頭文件數(shù)目比較多(如超過十個),通常應將頭文件和定義文件分別保存于不同的目錄,以便于維護。例如可將頭文件
7、保存于include目錄,將定義文件保存于source目錄(可以是多級目錄)。如果某些頭文件是私有的,它不會被用戶的程序直接引用,則沒有必要公開其“聲明”。為了加強信息隱藏,這些私有的頭文件可以和定義文件存放于同一個目錄。第2章程序的版式版式雖然不會影響程序的功能,但會影響可讀性。程序的版式追求清晰、美觀,是程序風格的重要構成因素??梢园殉绦虻陌媸奖扔鳛椤皶ā?。好的“書法”可讓人對程序一目了然,看得興致勃勃。差的程序“書法”如螃蟹爬行,讓人看得索然無味,更令維護者煩惱有加。請程序員們學習程序的“書法”,彌補大學計算機教育的漏洞,實在很有必要。2.1空
8、行空行起著分隔程序段落的作用??招械皿w(不過多也不過少)將使程序的布局更加清晰??招胁粫速M內(nèi)