源程序文檔化【業(yè)界薈萃】
《源程序文檔化【業(yè)界薈萃】》由會員分享,可在線閱讀,更多相關(guān)《源程序文檔化【業(yè)界薈萃】(36頁珍藏版)》請?jiān)谘b配圖網(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ù)成員(又叫實(shí)例變量或者成員變量)的命名與普通變量一樣,全部字母小寫,可選的下劃線分隔符,但應(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)的變量名匹配。下面顯示了一個類的部分摘錄,它有一個實(shí)例變量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ù)、變量和邏輯功能段進(jìn)行注釋的規(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、一個許可引用。選擇適合你項(xiàng)目使用的許可引用(比如Apache 2.0、BSD、LGPL、GPL)3、作者信息行說明文件原始作者如果你對
6、原始作者的文件做了實(shí)質(zhì)性修改,可以在作者信息行加上你的名字。當(dāng)其他開發(fā)者有問題時,這樣可以方便他們正確地聯(lián)系到修改者。9行業(yè)知識文件內(nèi)容注釋(File Contents)每個文件都應(yīng)該在其版權(quán)信息及作者信息后面和內(nèi)容前面有一個內(nèi)容描述性的注釋。通常,頭文件描述它所聲明的類的目的及用法。而源文件則應(yīng)該包含更多有關(guān)實(shí)現(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.如果你在文件開始就已對類進(jìn)行了詳細(xì)描述,可以在類實(shí)現(xiàn)部分簡單地聲明“參見文件開始注釋部分的完整描述”,但注意,這里還是要添加少量注釋。11行業(yè)知識函數(shù)注釋函數(shù)注釋(Function C
8、omments)函數(shù)聲明部分的注釋描述函數(shù)的用法,實(shí)現(xiàn)部分的注釋描述函數(shù)實(shí)現(xiàn)的操作。每個函數(shù)聲明的前面都應(yīng)該有一個描述函數(shù)功能和用法的注釋。這些注釋應(yīng)該是描述性(Opens the file),而不是祈使性的(Open the file),注釋僅僅描述函數(shù)能夠完成什么功能而不是函數(shù)是怎么實(shí)現(xiàn)的,這些應(yīng)該在函數(shù)實(shí)現(xiàn)的注釋中。在函數(shù)聲明注釋中應(yīng)該提到的信息類型:1、輸入和輸出;2、對于類成員函數(shù),在該方法的調(diào)用周期外,對象是否有引用參數(shù),它是否會釋放這些引用;3、如果一個函數(shù)申請了內(nèi)存,它必須釋放它們;4、參數(shù)是否可以是空;5、函數(shù)的使用方法是否會影響其性能;6、如果函數(shù)可重入。它是怎么實(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、回假的情況就沒必要,因?yàn)檫@很明顯:/ 如果表已被占滿,不能再容納實(shí)體,則返回真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ù)的功能和其完成這些功能的實(shí)現(xiàn)技巧(如果有的話)。比如,你在函數(shù)定義注釋中,你可以描述編碼中用到的技巧,給
11、出大致的執(zhí)行步驟或者解釋一下你選擇這種實(shí)現(xiàn)而不使用其他替代方法的原因。比如,你可能需要說明為什么函數(shù)前半部分需要鎖而后半部分不需要。注意,不能簡單地重復(fù)頭文件或者其他地方函數(shù)聲明部分的注釋??梢栽俅胃爬ㄒ幌潞瘮?shù)的功能,但焦點(diǎn)應(yīng)該是函數(shù)是怎么實(shí)現(xiàn)功能的。14行業(yè)知識變量注釋變量注釋(Variable Comments)通常,一個變量的實(shí)際名稱已經(jīng)提供了足夠和描述信息來說明其用途。但某些情況下,可能需要更多注釋。類數(shù)據(jù)成員(Class Data Members)每個類數(shù)據(jù)成員(也稱實(shí)例變量或者成員變量)應(yīng)該有一個描述其用途的注釋。如果這個變量能取得具有特殊意義的標(biāo)志值,比如NULL或-1,則需要加
12、以說明。比如:Private: /記錄表中實(shí)體的總數(shù) /用于確保不打破數(shù)量限制。 /-1意味著表的實(shí)體數(shù)未知 int num_total_entries;15行業(yè)知識全局變量(Global Variables)和數(shù)據(jù)成員一樣,所有全局變量應(yīng)該有一個描述其功能及其意義的注釋。比如/ 所有本次回歸測試使用到的測試用例數(shù)cosnt int kNumTestCases = 6;實(shí)現(xiàn)注釋(Implementation Comments)在實(shí)現(xiàn)中,應(yīng)該對你代碼技巧性的、不明顯的、有趣的或者重要的部分進(jìn)行注釋。類數(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è)知識邏輯功能段進(jìn)行注釋當(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個空格的縮進(jìn)Type par_nane2,Type par_name3) DoSomething();22行業(yè)知識需要注意的地方:返回類型應(yīng)該保持與函數(shù)名在同一行;左括號應(yīng)該與函數(shù)名保持在同一行且中間不應(yīng)該有空格;括號與參數(shù)之間不應(yīng)該有空格;左花括號應(yīng)該與最后一個參數(shù)保持在同一行;右花括號要么獨(dú)自一行,要么與左花括號保持在同一行(其他風(fēng)格規(guī)則允許時);右圓括號與左花括號之間應(yīng)該有一個空格隔開;無論是函數(shù)聲明還是函數(shù)實(shí)現(xiàn),都應(yīng)該給參數(shù)命以同樣的名稱;默認(rèn)縮進(jìn)2個空格;分行的參數(shù)以4個空格縮進(jìn);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ù)實(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ù)實(shí)現(xiàn)中,以注釋注明未使用的參數(shù)命名void Circle:Rotate(double /*radians*/)/ 不好如果以后需要其他人實(shí)現(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, / 縮進(jìn)4個空格 argument2, argument3, argument4);27行業(yè)知識條件語句條件語句(Conditonals)括號內(nèi)最好不要有空格,else應(yīng)該另起一行?;緱l件語句主要有兩種常見格式:一種是在括號和條件中插入空格,另一種是沒有。但后者更常用。盡管兩種方式都可以,但注意保持一致性。當(dāng)你修改別人的代碼時,保持與已有風(fēng)格的一致;而當(dāng)你添加新代碼時,與當(dāng)前目錄或項(xiàng)目中已有代碼的風(fēng)格保持一致。當(dāng)你不確定而且感覺無所謂時,不要插入空格。if(condition) / 括號內(nèi)沒有空格 . / 縮進(jìn)2個空格else / else與右花括號在同一行 .28行業(yè)知識當(dāng)然
24、,你也可以根據(jù)自己的喜好在括號內(nèi)插入空格if ( condition ) / 括號內(nèi)插入空格不常用 . / 縮進(jìn)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)加上圓括號后更具可讀性。一些項(xiàng)目甚至要求if在所有情況都應(yīng)該加上花括號。if ( condition ) DoSomething(); / 縮進(jìn)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)該加上花括號,因?yàn)樗鼈冎挥衖f (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,但不要用單獨(dú)的分號: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的次序定義,每個部分縮進(jìn)1個空格。下例顯示了基本的類格式(例子中缺少必要的注釋,參見類注釋(Class Comments)部分):class MyClass : public OtherClass public: / 注意,縮進(jìn)1個空格 MyClass(); / 注意,縮進(jìn)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:只需縮進(jìn)1個空格,且除非是第1個實(shí)例的情況,它們應(yīng)該位于單獨(dú)的行,最好在緊接著的下一行進(jìn)行成員聲明;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)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 第七章-透射電子顯微鏡
- 群落的結(jié)構(gòu)(課件)
- 焊接基礎(chǔ)知識
- 水文地質(zhì)學(xué)課件
- 某公司員工工傷安全管理規(guī)定
- 消防培訓(xùn)課件:安全檢修(要點(diǎn))
- 某公司安全生產(chǎn)考核與獎懲辦法范文
- 安全作業(yè)活動安全排查表
- 某公司危險(xiǎn)源安全辨識、分類和風(fēng)險(xiǎn)評價、分級辦法
- 某公司消防安全常識培訓(xùn)資料
- 安全培訓(xùn)資料:危險(xiǎn)化學(xué)品的類別
- 中小學(xué)寒假學(xué)習(xí)計(jì)劃快樂度寒假充實(shí)促成長
- 紅色插畫風(fēng)輸血相關(guān)知識培訓(xùn)臨床輸血流程常見輸血不良反應(yīng)
- 14.應(yīng)急救援隊(duì)伍訓(xùn)練記錄
- 某公司各部門及人員安全生產(chǎn)責(zé)任制