源程序文檔化【業(yè)界薈萃】

上傳人:8** 文檔編號:79537797 上傳時間:2022-04-23 格式:PPT 頁數(shù):36 大小:153.01KB
收藏 版權(quán)申訴 舉報 下載
源程序文檔化【業(yè)界薈萃】_第1頁
第1頁 / 共36頁
源程序文檔化【業(yè)界薈萃】_第2頁
第2頁 / 共36頁
源程序文檔化【業(yè)界薈萃】_第3頁
第3頁 / 共36頁

下載文檔到電腦,查找使用更方便

22 積分

下載資源

還剩頁未讀,繼續(xù)閱讀

資源描述:

《源程序文檔化【業(yè)界薈萃】》由會員分享,可在線閱讀,更多相關(guān)《源程序文檔化【業(yè)界薈萃】(36頁珍藏版)》請在裝配圖網(wǎng)上搜索。

1、軟件工程研討源程序文檔化第六組組員:12122208 陳帥12123298 馬敏12123249 雷晴12123256 邱可藝2014.12.161行業(yè)知識變量、常量和函數(shù)的命名規(guī)范2行業(yè)知識變量名所有字母小寫,單詞之間用下劃線(_)分開,類成員變量以下劃線結(jié)束。普通變量命名(Common Variable Names)比如:類數(shù)據(jù)組成變量命名(Class Data Members)數(shù)據(jù)成員(又叫實例變量或者成員變量)的命名與普通變量一樣,全部字母小寫,可選的下劃線分隔符,但應(yīng)該以下劃線結(jié)束。string table_name_; / 可以以下劃線結(jié)束string tablename_; /

2、可以變量命名變量命名(Variable Names)string table_name; / 可以使用下劃線string tablename; / 可以全部字母小寫string tableName; / 糟糕大小寫混合3行業(yè)知識結(jié)構(gòu)體成員變量命名(Struct Variables)結(jié)構(gòu)體成員變量和普通變量命名規(guī)則一致,且不像類成員變量以下劃線結(jié)束。struct UrlTableProperties string name; int num_entries;全局變量命名(Global Variables)全局變量的使用較為罕見,但當(dāng)用到時,考慮以前綴g_開頭或標(biāo)以其他記號,以便與局部變量區(qū)分。4

3、行業(yè)知識常量命名常量命名(Constant Names)K后跟混合大小寫的名稱:kDaysInAWeek。所有編譯時常量,不管是被聲明為局部、全局還是作為類的成員,都應(yīng)該遵守與其他變量命名有輕微差別的命名約定:k后跟單詞首字母大寫的名稱:const int kDaysInAWeek = 7;5行業(yè)知識函數(shù)命名函數(shù)命名(Function Names)正規(guī)函數(shù)名應(yīng)該以大寫字母開頭,單詞首字母大寫,不使用下劃線。如果函數(shù)可能因錯誤而崩潰,應(yīng)該在函數(shù)名后加上OrDie。這僅適用于那些被產(chǎn)品代碼調(diào)用或者正常操作有可能引起錯誤的函數(shù)。AddTableEntry()DeleteUrl()OpenFileOr

4、Die()6行業(yè)知識訪問器和修改器(Accessors and Mutators)訪問器和修改器(get和set函數(shù))應(yīng)該與它們關(guān)聯(lián)的變量名匹配。下面顯示了一個類的部分摘錄,它有一個實例變量num_entriesclass MyClass public:.int num_entries() constreturn num_entries;v o i d s e t _ n u m _ e n t r i e s ( i n t num_entries)num_entries = num_entries;private: int num_entries_;你也可以使用小寫字母和下劃線來命名非常短

5、小的內(nèi)聯(lián)函數(shù)。比如,如果一個函數(shù)的調(diào)用開銷很小,在循環(huán)調(diào)用時,沒必要緩存其值,這時,小寫字母命名是允許的。7行業(yè)知識對文件、類、函數(shù)、變量和邏輯功能段進行注釋的規(guī)范8行業(yè)知識 文件注釋文件注釋(File Comments)每個文件都應(yīng)該提供版權(quán)信息,然后是文件內(nèi)容的綜合性描述。合法公告和作者信息行(Legal Notice and Author Line)每個文件都應(yīng)依次包括以下條目,1、版權(quán)聲明(比如Copyright 2008 Google Inc.);2、一個許可引用。選擇適合你項目使用的許可引用(比如Apache 2.0、BSD、LGPL、GPL)3、作者信息行說明文件原始作者如果你對

6、原始作者的文件做了實質(zhì)性修改,可以在作者信息行加上你的名字。當(dāng)其他開發(fā)者有問題時,這樣可以方便他們正確地聯(lián)系到修改者。9行業(yè)知識文件內(nèi)容注釋(File Contents)每個文件都應(yīng)該在其版權(quán)信息及作者信息后面和內(nèi)容前面有一個內(nèi)容描述性的注釋。通常,頭文件描述它所聲明的類的目的及用法。而源文件則應(yīng)該包含更多有關(guān)實現(xiàn)和技巧性算法的討論信息。但如果你覺得這些信息對于頭文件的閱讀者更有用,可以將其放在頭文件中,但在源文件中應(yīng)該注明其文檔在頭文件中。不要在頭文件和源文件中重復(fù)注釋,這樣容易造成歧義。10行業(yè)知識類注釋類注釋(Class Comments)每個類定義都應(yīng)該伴隨有說明其目的和用法的注釋。/

7、 遍歷GargantuanTable的內(nèi)容。用法示例:/ GargantuanTableIterator* iter = table-NewIterator();/ for(iter-seek(“foo”);!iter-done();iter-next()/ process(iter-key(),iter-value();/ / delete iter;Class GargantuanTableIterator.如果你在文件開始就已對類進行了詳細(xì)描述,可以在類實現(xiàn)部分簡單地聲明“參見文件開始注釋部分的完整描述”,但注意,這里還是要添加少量注釋。11行業(yè)知識函數(shù)注釋函數(shù)注釋(Function C

8、omments)函數(shù)聲明部分的注釋描述函數(shù)的用法,實現(xiàn)部分的注釋描述函數(shù)實現(xiàn)的操作。每個函數(shù)聲明的前面都應(yīng)該有一個描述函數(shù)功能和用法的注釋。這些注釋應(yīng)該是描述性(Opens the file),而不是祈使性的(Open the file),注釋僅僅描述函數(shù)能夠完成什么功能而不是函數(shù)是怎么實現(xiàn)的,這些應(yīng)該在函數(shù)實現(xiàn)的注釋中。在函數(shù)聲明注釋中應(yīng)該提到的信息類型:1、輸入和輸出;2、對于類成員函數(shù),在該方法的調(diào)用周期外,對象是否有引用參數(shù),它是否會釋放這些引用;3、如果一個函數(shù)申請了內(nèi)存,它必須釋放它們;4、參數(shù)是否可以是空;5、函數(shù)的使用方法是否會影響其性能;6、如果函數(shù)可重入。它是怎么實現(xiàn)同步的

9、?12行業(yè)知識例子:/ 返回這個表的一個迭代器/ 當(dāng)遍歷結(jié)束時,由客戶程序負(fù)責(zé)迭代器的釋放/ 一旦此迭代器的創(chuàng)建者GargantuanTable對象被釋放/ 客戶程序不可再使用此迭代器/ 迭代器被初始化為指向表的開始/ 這個方法等價于:/ Iterator *iter = table-NewIterator();iter-seek(“”);return iter;/ 如果你想立即尋找返回的迭代器中的另一個位置,使用NewIterator()更快,而/ 且避免了額外的查找。Iterator* getIterator()const然而,避免不必要的冗長注釋且不要添加顯而易見的注釋。比如下例外中,返

10、回假的情況就沒必要,因為這很明顯:/ 如果表已被占滿,不能再容納實體,則返回真bool IsTableFull();13行業(yè)知識當(dāng)給構(gòu)造和析構(gòu)函數(shù)加注釋時,注意,讀者清楚地知道這些函數(shù)的作用,所以諸如“銷毀這個對象”的注釋毫無意義。注釋內(nèi)容應(yīng)該說明構(gòu)造函數(shù)怎樣處理參數(shù)(比如它是否取得指針的控制權(quán))和析構(gòu)函數(shù)怎么完成清理工作。如果這些不很重要,可以省略它們。文件的開頭注釋中沒有關(guān)于析構(gòu)函數(shù)的注釋是很正常的。函數(shù)定義注釋(Function Definition)每個函數(shù)都應(yīng)該有一個注釋來描述函數(shù)的功能和其完成這些功能的實現(xiàn)技巧(如果有的話)。比如,你在函數(shù)定義注釋中,你可以描述編碼中用到的技巧,給

11、出大致的執(zhí)行步驟或者解釋一下你選擇這種實現(xiàn)而不使用其他替代方法的原因。比如,你可能需要說明為什么函數(shù)前半部分需要鎖而后半部分不需要。注意,不能簡單地重復(fù)頭文件或者其他地方函數(shù)聲明部分的注釋。可以再次概括一下函數(shù)的功能,但焦點應(yīng)該是函數(shù)是怎么實現(xiàn)功能的。14行業(yè)知識變量注釋變量注釋(Variable Comments)通常,一個變量的實際名稱已經(jīng)提供了足夠和描述信息來說明其用途。但某些情況下,可能需要更多注釋。類數(shù)據(jù)成員(Class Data Members)每個類數(shù)據(jù)成員(也稱實例變量或者成員變量)應(yīng)該有一個描述其用途的注釋。如果這個變量能取得具有特殊意義的標(biāo)志值,比如NULL或-1,則需要加

12、以說明。比如:Private: /記錄表中實體的總數(shù) /用于確保不打破數(shù)量限制。 /-1意味著表的實體數(shù)未知 int num_total_entries;15行業(yè)知識全局變量(Global Variables)和數(shù)據(jù)成員一樣,所有全局變量應(yīng)該有一個描述其功能及其意義的注釋。比如/ 所有本次回歸測試使用到的測試用例數(shù)cosnt int kNumTestCases = 6;實現(xiàn)注釋(Implementation Comments)在實現(xiàn)中,應(yīng)該對你代碼技巧性的、不明顯的、有趣的或者重要的部分進行注釋。類數(shù)據(jù)成員(Class Data Members)技巧性的和復(fù)雜難懂的代碼塊前應(yīng)該有注釋:/ Di

13、vide result by two, taking into account that x / contains the carry from the addfor(int i = 0;i size();i+) x = (x 1; X &= 1;16行業(yè)知識行注釋(Line Comments)同樣,當(dāng)行代碼中有不明顯的地方時,也需要在其行末添加注釋。這種行末注釋應(yīng)該以2個空白與代碼分開。/ If we have enough money, mmap the data portion too.mmap_budget = max(0,mmap_budget index_-length();i f

14、 ( m m a p _ b u d g e t = d a t a _ s i z e & !mmapData(mmap_chunk_bytes,mlock)return; / Error already logged.可以看到,這里即有描述代碼功能的注釋,也有提醒函數(shù)返回時錯誤已經(jīng)被記錄的注釋。如果有多行注釋,將它們整齊排列將增加可讀性。DoSomething(); / Comment here so the comments line upDoSomethingElseThatIsLong(); / Comment here so there are two spaces / betwe

15、en the code and the comment/ One space before commnet when opening a new scope is allowed, / thus the comment lines up with the following comments and code DoSomethingElse(); / Two spaces before line comments normally17行業(yè)知識邏輯功能段進行注釋當(dāng)給函數(shù)傳入NULL、布爾值和整型值串時,應(yīng)該增加注釋以說明這些值的意義,或者你可以使用常量使代碼自文檔化。比較以下兩段代碼:bool

16、success = CalculateSomething(interesting_value, 10, false, NULL);/這些參數(shù)都是什么意思?VSbool success = CalculateSomething(interesting_value, 10, /默認(rèn)基數(shù) flase,/非第一次調(diào)用 NULL);/無回調(diào)18行業(yè)知識也可以使用替代方案,常量或自描述的變量:const int kDefaultBaseValue = 10;const bool kFirstTimeCalling = false;callback *null_callback = NULL;bool su

17、ccess = CalculateSomething(interesting_value, kDefaultBaseValue, kFirstTimeCalling, null_callback);不要這么做:不要試圖描述代碼本身。假設(shè)代碼閱讀者比你更了解C+,既使這樣,他/她也對你到底想做什么毫無頭緒。/ 現(xiàn)在遍歷b數(shù)組并且確保如果i存在,下一個元素是i+1。./ 天哪,這些都是垃圾注釋19行業(yè)知識函數(shù)聲明和定義、函數(shù)調(diào)用、條件語句、循環(huán)語句和類的格式規(guī)范20行業(yè)知識函數(shù)聲明與定義(Function Declarations and Definitions)返回類型和函數(shù)名在同一行,如果空間

18、足夠,參數(shù)列表也應(yīng)在同一行。即:ReturnType ClassName:FunctionName(Type par_name1,Type par_name2) DoSomething(); .如果一行輸入不完,可以分成多行:ReturnType ClassName:ReallyLongFunctionName(Type par_name1,Type par_name2, Type par_name3) DoSomething(); .21行業(yè)知識也可以每個參數(shù)各占一行:ReturnType LongClassName:ReallyRealyReallyLongFunctionName(Typ

19、e par_name1, / 4個空格的縮進Type par_nane2,Type par_name3) DoSomething();22行業(yè)知識需要注意的地方:返回類型應(yīng)該保持與函數(shù)名在同一行;左括號應(yīng)該與函數(shù)名保持在同一行且中間不應(yīng)該有空格;括號與參數(shù)之間不應(yīng)該有空格;左花括號應(yīng)該與最后一個參數(shù)保持在同一行;右花括號要么獨自一行,要么與左花括號保持在同一行(其他風(fēng)格規(guī)則允許時);右圓括號與左花括號之間應(yīng)該有一個空格隔開;無論是函數(shù)聲明還是函數(shù)實現(xiàn),都應(yīng)該給參數(shù)命以同樣的名稱;默認(rèn)縮進2個空格;分行的參數(shù)以4個空格縮進;23行業(yè)知識定義const函數(shù)時,const關(guān)鍵字應(yīng)該與最后一個參數(shù)保持

20、在同一行。/ 這個函數(shù)簽名中的所有代碼不超過80個字符ReturnType FunctionName(Type par) const ./ 這個函數(shù)簽名需要分行,但注意,const與最后一個參數(shù)保持在同一行ReturnType ReallyLongFunctionName(Type par1, Type par2)const .24行業(yè)知識如果有未使用參數(shù),在函數(shù)實現(xiàn)中注釋其名稱:/ 在接口中,參數(shù)一定要命名class Shape public:virtual void Rotate(double radians) = 0;/ 在聲明中,參數(shù)一定要命名class Circle : public

21、 Shape virtual void Rotate(double radians);/ 在函數(shù)實現(xiàn)中,以注釋注明未使用的參數(shù)命名void Circle:Rotate(double /*radians*/)/ 不好如果以后需要其他人實現(xiàn),參數(shù)名稱不詳void Circle:Rotate(double)25行業(yè)知識函數(shù)調(diào)用函數(shù)調(diào)用(Function Calls)盡量書寫在一行,如果字符太多,將參數(shù)分行。比如:bool retval = DoSomething(argument1,argument2,argumetn3);如果參數(shù)無法在同一行內(nèi)寫完,可以分行,每一行的參數(shù)都應(yīng)該與第一個參數(shù)對齊,且

22、不要在左圓括號后或右圓括號前加空格。bool retval = DoSomething(averyveryveryverylongargument1, argument2,argument3);如果函數(shù)參數(shù)太多,可以每一行寫一個參數(shù),這樣代碼更可讀:bool retval = DoSomething(argument1, argument2, argument3, argument4);26行業(yè)知識如果參數(shù)簽名太長,超過最大行寬,可以將參數(shù)分行寫書:if(.) . . if(.) DoSomethingTheatRequiresALongFunctionName( very_long_argu

23、ment1, / 縮進4個空格 argument2, argument3, argument4);27行業(yè)知識條件語句條件語句(Conditonals)括號內(nèi)最好不要有空格,else應(yīng)該另起一行?;緱l件語句主要有兩種常見格式:一種是在括號和條件中插入空格,另一種是沒有。但后者更常用。盡管兩種方式都可以,但注意保持一致性。當(dāng)你修改別人的代碼時,保持與已有風(fēng)格的一致;而當(dāng)你添加新代碼時,與當(dāng)前目錄或項目中已有代碼的風(fēng)格保持一致。當(dāng)你不確定而且感覺無所謂時,不要插入空格。if(condition) / 括號內(nèi)沒有空格 . / 縮進2個空格else / else與右花括號在同一行 .28行業(yè)知識當(dāng)然

24、,你也可以根據(jù)自己的喜好在括號內(nèi)插入空格if ( condition ) / 括號內(nèi)插入空格不常用 . / 縮進2個空格else / else與右花括號在同一行 .注意:if和左圓括號之間應(yīng)該有空格。右圓括號和左花括號(如果使用)之間也應(yīng)該有空格。if(condition) / 糟糕IF后面沒有空格if (condition) / 糟糕右圓括號和左花括號之間沒有空格if(condition) / 非常糟糕29行業(yè)知識為便于閱讀,簡短的條件語句可以寫在同一行。但僅限于這行代碼很明確且沒有else分支的情況:if (x = kFoo) return new Foo();if (x = kBar)

25、return new Bar();/ if語句有else分支,不允許寫在同一行if (x) DoThis();else DoThat();通常,單語句條件語句不需要花括號,但可以根據(jù)自己的喜好加上。有復(fù)雜條件和語句的條件和循環(huán)加上圓括號后更具可讀性。一些項目甚至要求if在所有情況都應(yīng)該加上花括號。if ( condition ) DoSomething(); / 縮進2個空格if (condition) DoSomethign();30行業(yè)知識為保持一致,if或者else分支加了花括號,另一分支也應(yīng)該加上。/ 不允許if分支有花括號,而else分支沒有if (condition) foo;el

26、se Bar;/ 不允許else分支有花括號,而if分支沒有If (condition) foo;else bar;/ if和else分支都應(yīng)該加上花括號,因為它們之一有if (condition) foo;else Bar;31行業(yè)知識循環(huán)和多分支語句循環(huán)和多分支語句(Loops and Switch Statements)在多分支語句中,塊可以用花括號限制。而對于無循環(huán)體的循環(huán),可以使用或continue。case語句塊可根據(jù)自己的喜好使用花括號,如果使用花括號,請遵照下面的格式:除非是判斷枚舉類型,多分支語句應(yīng)該有一個默認(rèn)分支(在枚舉情況下,編譯器將檢測到未處理分支并警告)。如果默認(rèn)分支

27、不可能被執(zhí)行,使用斷言(assert)聲明。swtich (var) case 0: .Break;case 1: . Break;default: assert(false);32行業(yè)知識空循環(huán)體應(yīng)該用或者continue,但不要用單獨的分號:while (condition) / 一直測試條件,直到它返回假for(int i = 0; i kSomeNumber;+i) / 很好空循環(huán)體while (condtiton) continue; / 很好continue指示無邏輯while (condition); / 糟糕看起來像是do/while循環(huán)33行業(yè)知識類格式(Class Form

28、at)成員按public、protected和private的次序定義,每個部分縮進1個空格。下例顯示了基本的類格式(例子中缺少必要的注釋,參見類注釋(Class Comments)部分):class MyClass : public OtherClass public: / 注意,縮進1個空格 MyClass(); / 注意,縮進2個空格 Explicit MyClass(int var); MyClass() void SomeFunction(); void SomeFunctionThatDoesNothing()void set_some_var(int var) some_var

29、= var; int some_var() const reurn some_var; private: bool SomeInternalFunction(); int some_var; int some_other_var; DISALLOW_COPY_AND_ASSIGN(MyClass);34行業(yè)知識注意:基類名稱直接置于子類名稱后的同一行內(nèi)而不受最大長度(80字符)的限制;public:protected:和private:只需縮進1個空格,且除非是第1個實例的情況,它們應(yīng)該位于單獨的行,最好在緊接著的下一行進行成員聲明;public部分行1位、protected部分第2位,private放在最后;35行業(yè)知識謝謝36行業(yè)知識

展開閱讀全文
溫馨提示:
1: 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
2: 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
3.本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
5. 裝配圖網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

相關(guān)資源

更多
正為您匹配相似的精品文檔
關(guān)于我們 - 網(wǎng)站聲明 - 網(wǎng)站地圖 - 資源地圖 - 友情鏈接 - 網(wǎng)站客服 - 聯(lián)系我們

copyright@ 2023-2025  zhuangpeitu.com 裝配圖網(wǎng)版權(quán)所有   聯(lián)系電話:18123376007

備案號:ICP2024067431-1 川公網(wǎng)安備51140202000466號


本站為文檔C2C交易模式,即用戶上傳的文檔直接被用戶下載,本站只是中間服務(wù)平臺,本站所有文檔下載所得的收益歸上傳人(含作者)所有。裝配圖網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對上載內(nèi)容本身不做任何修改或編輯。若文檔所含內(nèi)容侵犯了您的版權(quán)或隱私,請立即通知裝配圖網(wǎng),我們立即給予刪除!