軟件開(kāi)發(fā)流程管理制度及軟件開(kāi)發(fā)流程規(guī)范_第1頁(yè)
軟件開(kāi)發(fā)流程管理制度及軟件開(kāi)發(fā)流程規(guī)范_第2頁(yè)
軟件開(kāi)發(fā)流程管理制度及軟件開(kāi)發(fā)流程規(guī)范_第3頁(yè)
軟件開(kāi)發(fā)流程管理制度及軟件開(kāi)發(fā)流程規(guī)范_第4頁(yè)
軟件開(kāi)發(fā)流程管理制度及軟件開(kāi)發(fā)流程規(guī)范_第5頁(yè)
已閱讀5頁(yè),還剩47頁(yè)未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說(shuō)明:本文檔由用戶(hù)提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

軟件開(kāi)發(fā)流程管理制度(討論稿)為加強(qiáng)對(duì)定制軟件開(kāi)發(fā)工作管理,縮短開(kāi)發(fā)周期,提高軟件開(kāi)發(fā)質(zhì)量,降低開(kāi)發(fā)成本,提高定開(kāi)發(fā)效率和效益,特制定軟件開(kāi)發(fā)流程管理制度。第一章、總則為保證日常工作正常有序的進(jìn)行,讓開(kāi)發(fā)中各個(gè)環(huán)境更緊湊,更可控,需要盡可能實(shí)現(xiàn)項(xiàng)目管理的正規(guī)化,工作過(guò)程的流程化,以便提高軟件質(zhì)量,按期交付。1、軟件開(kāi)發(fā)總體遵循項(xiàng)目管理和軟件工程的基本原則。2、項(xiàng)目管理涉及項(xiàng)目立項(xiàng)、項(xiàng)目計(jì)劃和監(jiān)控、配置管理。3、軟件工程涉及需求分析、系統(tǒng)設(shè)計(jì)、軟件實(shí)現(xiàn)、系統(tǒng)測(cè)試、用戶(hù)測(cè)試、試運(yùn)行、系統(tǒng)驗(yàn)收、系統(tǒng)上線和數(shù)據(jù)遷移、產(chǎn)品維護(hù)。第二章、階段成果根據(jù)軟件工程的過(guò)程,制定以下工作流程,并規(guī)定了各個(gè)重要環(huán)節(jié)需要提交的交付物。各階段需提交的文檔:1、立項(xiàng):項(xiàng)目申請(qǐng)表,軟件需求報(bào)告或設(shè)計(jì)方案。2、需求分析:項(xiàng)目研發(fā)主計(jì)劃、需求規(guī)格說(shuō)明書(shū)3、總體設(shè)計(jì):概要設(shè)計(jì)說(shuō)明書(shū)或功能模塊描述4、詳細(xì)設(shè)計(jì):詳細(xì)設(shè)計(jì)說(shuō)明書(shū),包括軟件接口說(shuō)明、單元測(cè)試計(jì)劃。5、軟件實(shí)現(xiàn):軟件功能說(shuō)明、源代碼說(shuō)明或者注釋6、產(chǎn)品測(cè)試:測(cè)試報(bào)告7、產(chǎn)品發(fā)布:產(chǎn)品說(shuō)明書(shū)、使用手冊(cè)8、產(chǎn)品維護(hù):?jiǎn)栴}反饋記錄9、項(xiàng)目總結(jié):提交客戶(hù)方的項(xiàng)目總結(jié)和公司項(xiàng)目匯報(bào)的PPT。軟件過(guò)程成果表:階段形成文檔職責(zé)及文檔成果描述負(fù)責(zé)人涉及范圍備注需求階段項(xiàng)目立項(xiàng)報(bào)告(Word)明確甲乙雙方責(zé)任及義務(wù),需雙方簽字確認(rèn)項(xiàng)目經(jīng)理驗(yàn)收?qǐng)?bào)告大部分業(yè)務(wù)建模和需求,少部分分析設(shè)計(jì)業(yè)務(wù)需求說(shuō)明書(shū)(Word)需求定義,闡述業(yè)務(wù)范圍及內(nèi)容,開(kāi)發(fā)組負(fù)責(zé)制定最優(yōu)技術(shù)設(shè)計(jì)方案項(xiàng)目經(jīng)理/分析員驗(yàn)收?qǐng)?bào)告項(xiàng)目開(kāi)發(fā)計(jì)劃(Project)用戶(hù)、領(lǐng)導(dǎo)、項(xiàng)目組都了解項(xiàng)目進(jìn)度項(xiàng)目經(jīng)理驗(yàn)收?qǐng)?bào)告設(shè)計(jì)階段業(yè)務(wù)流程總體設(shè)計(jì)書(shū)、詳細(xì)設(shè)計(jì)說(shuō)明書(shū)(Word/Visio)項(xiàng)目組成員分配任務(wù),并召開(kāi)討論會(huì)議,討論項(xiàng)目的技術(shù)架構(gòu)和可能存在的技術(shù)難點(diǎn),梳理業(yè)務(wù)流程,統(tǒng)一開(kāi)發(fā)規(guī)則和風(fēng)格等項(xiàng)目經(jīng)理/分析員驗(yàn)收?qǐng)?bào)告大部分分析設(shè)計(jì),部分實(shí)施編程及測(cè)試,開(kāi)始考慮部署數(shù)據(jù)庫(kù)關(guān)系設(shè)計(jì)圖、流程圖(PowerDesigner)便于項(xiàng)目開(kāi)發(fā)分析員驗(yàn)收?qǐng)?bào)告任務(wù)分配文檔(Word)明確每個(gè)組員的開(kāi)發(fā)任務(wù)及職責(zé)項(xiàng)目經(jīng)理過(guò)程報(bào)告問(wèn)題說(shuō)明報(bào)告(Word)讓用戶(hù)、領(lǐng)導(dǎo)及組員及時(shí)了解和發(fā)現(xiàn)問(wèn)題項(xiàng)目經(jīng)理過(guò)程報(bào)告業(yè)務(wù)變更文檔(Word)記錄開(kāi)發(fā)過(guò)程中用戶(hù)提出的業(yè)務(wù)需求變更情況分析員過(guò)程報(bào)告測(cè)試階段項(xiàng)目測(cè)試方案及報(bào)告(Word)記錄項(xiàng)目測(cè)試的方法,驗(yàn)證系統(tǒng)功能與性能的記錄測(cè)試員驗(yàn)收?qǐng)?bào)告反復(fù)測(cè)試直至系統(tǒng)穩(wěn)定用戶(hù)使用手冊(cè)(Word)方便用戶(hù)使用軟件而提供的使用說(shuō)明書(shū)測(cè)試員驗(yàn)收?qǐng)?bào)告上線及運(yùn)行系統(tǒng)切換報(bào)告系統(tǒng)部署后的操作記錄項(xiàng)目經(jīng)理過(guò)程報(bào)告部署及維護(hù)用戶(hù)培訓(xùn)報(bào)告用戶(hù)培訓(xùn)文檔項(xiàng)目經(jīng)理過(guò)程報(bào)告項(xiàng)目驗(yàn)收?qǐng)?bào)告(Word)記錄甲乙雙方簽訂項(xiàng)目驗(yàn)收?qǐng)?bào)告項(xiàng)目經(jīng)理驗(yàn)收?qǐng)?bào)告項(xiàng)目總結(jié)性報(bào)告項(xiàng)目組通過(guò)此項(xiàng)目總結(jié)經(jīng)驗(yàn)及不足項(xiàng)目經(jīng)理總結(jié)報(bào)告第三章、崗位設(shè)置根據(jù)公司目前的開(kāi)發(fā)過(guò)程主要分為分析、開(kāi)發(fā)、測(cè)試三個(gè)階段。分析階段完成用戶(hù)需求文檔的編寫(xiě),系統(tǒng)總體設(shè)計(jì)的編寫(xiě);開(kāi)發(fā)階段完成設(shè)計(jì)文檔的編寫(xiě),代碼的編寫(xiě)、代碼的維護(hù)。測(cè)試階段完成系統(tǒng)的測(cè)試,測(cè)試文檔及其他材料。通過(guò)逐漸的調(diào)整崗位,明確工作職責(zé),逐步實(shí)現(xiàn)項(xiàng)目經(jīng)理,軟件設(shè)計(jì)師,程序員,測(cè)試工程師的崗位設(shè)置。崗位工作內(nèi)容責(zé)任項(xiàng)目經(jīng)理1、選定項(xiàng)目組成員,成立項(xiàng)目組,安排任務(wù)分工2、與客戶(hù)進(jìn)行溝通和協(xié)調(diào)(業(yè)務(wù)需求或非業(yè)務(wù)需求方面),以及需求調(diào)研工作。3、制定開(kāi)發(fā)主計(jì)劃,包括需求,設(shè)計(jì),編碼,測(cè)試這幾個(gè)階段的計(jì)劃。4、估計(jì)項(xiàng)目開(kāi)發(fā)費(fèi)用5、制定小組開(kāi)發(fā)進(jìn)度表,對(duì)組內(nèi)人員工作進(jìn)度監(jiān)控。6、和客戶(hù)進(jìn)行溝通,進(jìn)行需求調(diào)研,匯總需求分析文檔,并編寫(xiě)系統(tǒng)總體設(shè)計(jì)方案7、對(duì)文檔的質(zhì)量進(jìn)行檢查、把關(guān)8、對(duì)組內(nèi)成員的工作進(jìn)行指導(dǎo)1、對(duì)客戶(hù)的溝通協(xié)調(diào)工作負(fù)責(zé);2、對(duì)軟件的開(kāi)發(fā)效率、質(zhì)量、費(fèi)用負(fù)責(zé)3、對(duì)用戶(hù)的需求分析的質(zhì)量負(fù)責(zé);4、對(duì)系統(tǒng)總體設(shè)計(jì)、詳細(xì)設(shè)計(jì)文檔質(zhì)量負(fù)責(zé)軟件設(shè)計(jì)師1、負(fù)責(zé)系統(tǒng)的模塊設(shè)計(jì),詳細(xì)設(shè)計(jì)文檔2、繪制界面原型demo等,設(shè)計(jì)功能使用的具體描述、行為者、前置條件、后置條件、UI描述、業(yè)務(wù)流程/子流程/分支流程,界面說(shuō)明等,完成大部分的前端設(shè)計(jì),小部分的后端設(shè)計(jì)。3、負(fù)責(zé)技術(shù)難度大的模塊的代碼或者公用模塊代碼的編寫(xiě)、維護(hù)4、對(duì)自己負(fù)責(zé)模塊的詳細(xì)設(shè)計(jì)、代碼編寫(xiě)。5、對(duì)小組內(nèi)人員進(jìn)行技術(shù)指導(dǎo)1、對(duì)組內(nèi)人員的開(kāi)發(fā)效率負(fù)責(zé);2、對(duì)產(chǎn)品整體風(fēng)格負(fù)責(zé)3、對(duì)項(xiàng)目整體設(shè)計(jì)流程負(fù)責(zé);4、對(duì)自己模塊的開(kāi)發(fā)效率和質(zhì)量負(fù)責(zé)。程序員1、與項(xiàng)目經(jīng)理溝通和確認(rèn)某個(gè)模塊的需求和實(shí)現(xiàn)方法2、負(fù)責(zé)某個(gè)模塊的代碼編寫(xiě)、維護(hù)3、對(duì)其他模塊的代碼的維護(hù)4、負(fù)責(zé)與測(cè)試人員的交互,處理測(cè)試人員的問(wèn)題1、對(duì)自己模塊的開(kāi)發(fā)效率和質(zhì)量負(fù)責(zé)。測(cè)試工程師1、根據(jù)用戶(hù)需求分析和系統(tǒng)總體設(shè)計(jì),編寫(xiě)測(cè)試文檔和測(cè)試用例。2、對(duì)系統(tǒng)的功能、性能、異常進(jìn)行測(cè)試。3、編寫(xiě)測(cè)試文檔和操作指導(dǎo)手冊(cè)。1、對(duì)測(cè)試的質(zhì)量負(fù)責(zé)2、對(duì)測(cè)試文檔和操作手冊(cè)的質(zhì)量負(fù)責(zé)。第四章、項(xiàng)目立項(xiàng)1、分析人員進(jìn)行應(yīng)用調(diào)查與分析,確認(rèn)軟件的應(yīng)用需求。2、成立項(xiàng)目評(píng)審會(huì),開(kāi)發(fā)總監(jiān)、部門(mén)經(jīng)理和指定人員必須參加。對(duì)項(xiàng)目進(jìn)行可行性研究,編寫(xiě)項(xiàng)目建議書(shū),評(píng)估項(xiàng)目的難度和工作量,形成可行性研究報(bào)告。3、根據(jù)項(xiàng)目配置的優(yōu)劣成立項(xiàng)目開(kāi)發(fā)組,制定軟件開(kāi)發(fā)計(jì)劃,確定項(xiàng)目經(jīng)理,由部門(mén)和項(xiàng)目經(jīng)理共同來(lái)確定具體項(xiàng)目配置,知識(shí)技能要求,團(tuán)隊(duì)成員及團(tuán)隊(duì)的角色。第五章、項(xiàng)目計(jì)劃與監(jiān)控1、以項(xiàng)目為單位,項(xiàng)目經(jīng)理負(fù)責(zé)整個(gè)項(xiàng)目的計(jì)劃、組織和控制。2、在整個(gè)項(xiàng)目過(guò)程中,項(xiàng)目經(jīng)理定期檢查項(xiàng)目進(jìn)度和完成情況,調(diào)整人員分工和安排。3、項(xiàng)目計(jì)劃需要變更時(shí),需要明確變更內(nèi)容并及時(shí)匯報(bào)。項(xiàng)目經(jīng)理需要說(shuō)明客戶(hù)變更原因并將變更說(shuō)明提交公司領(lǐng)導(dǎo)審核,以便根據(jù)變更內(nèi)容及時(shí)調(diào)整計(jì)劃。。第六章、需求分析1、對(duì)用戶(hù)提出的需求進(jìn)行分析匯總,梳理用戶(hù)的業(yè)務(wù)流程和詳細(xì)的功能定義。2、做出簡(jiǎn)單的界面原型,與客戶(hù)進(jìn)行有效的溝通,編寫(xiě)需求詳細(xì)說(shuō)明書(shū)。3、根據(jù)現(xiàn)有條件進(jìn)行估計(jì),制定項(xiàng)目進(jìn)度,制定詳細(xì)的軟件開(kāi)發(fā)計(jì)劃。第七章、總體設(shè)計(jì)1、在該階段確定總體結(jié)構(gòu)和軟件開(kāi)發(fā)架構(gòu),文件命名規(guī)范,編碼規(guī)范。可按軟件需求劃分成子系統(tǒng),也可直接定義目標(biāo)系統(tǒng)的功能模塊及各個(gè)功能模塊的關(guān)系。3、確定軟件模塊結(jié)構(gòu),給出每個(gè)功能模塊的功能描述、數(shù)據(jù)接口描述,并完成系統(tǒng)概要設(shè)計(jì)說(shuō)明書(shū)。4、完成數(shù)據(jù)庫(kù)的設(shè)計(jì),并編寫(xiě)數(shù)據(jù)庫(kù)設(shè)計(jì)說(shuō)明書(shū)。5、完成的文檔需提交公司進(jìn)行歸檔管理。第八章、詳細(xì)設(shè)計(jì)1、調(diào)整前一步設(shè)計(jì)的不足,確認(rèn)各模塊之間的詳細(xì)接口信息。2、設(shè)計(jì)功能使用的具體描述、行為者、前置條件、后置條件、UI描述、業(yè)務(wù)流程/子流程/分支流程,界面說(shuō)明等。3、確定模塊內(nèi)的數(shù)據(jù)流或控制流,對(duì)每個(gè)程序模塊必須確定所有輸入、輸出和處理功能。4、匯總并提交所有相關(guān)文檔,審核確認(rèn)質(zhì)量和進(jìn)度。第九章、軟件實(shí)現(xiàn)1、項(xiàng)目組根據(jù)概要設(shè)計(jì)說(shuō)明書(shū)、詳細(xì)設(shè)計(jì)說(shuō)明書(shū)制定系統(tǒng)實(shí)現(xiàn)計(jì)劃2、有條件的情況下保證開(kāi)發(fā)、測(cè)試和生產(chǎn)環(huán)境獨(dú)立。選擇軟件工具,明確項(xiàng)目成員的職責(zé)分工,按照編碼規(guī)范和詳細(xì)設(shè)計(jì)實(shí)現(xiàn)軟件功能。3、代碼應(yīng)滿(mǎn)足結(jié)構(gòu)良好,清晰易讀,且與設(shè)計(jì)一致,符合編碼規(guī)范。4、開(kāi)發(fā)人員需要軟件實(shí)現(xiàn)過(guò)程中編寫(xiě)軟件功能說(shuō)明,源代碼說(shuō)明。軟件功能說(shuō)明文檔應(yīng)說(shuō)明項(xiàng)目名稱(chēng)、編號(hào)、軟件名稱(chēng)和版本號(hào),軟件功能、主要功能實(shí)現(xiàn)過(guò)程。源代碼說(shuō)明應(yīng)說(shuō)明項(xiàng)目編號(hào)、軟件名稱(chēng)、功能,全局變量、數(shù)據(jù)庫(kù)字典、函數(shù)功能、接口。該文檔包含在源代碼文件中,以注釋形式存在。5、項(xiàng)目組進(jìn)行單元測(cè)試和集成測(cè)試。開(kāi)發(fā)人員處理測(cè)試人員反饋的測(cè)試問(wèn)題,并以書(shū)面形式反饋主要問(wèn)題及解決辦法,直至系統(tǒng)運(yùn)行穩(wěn)定。6、匯總并提交所有相關(guān)文檔,提交公司備案。第十章、軟件測(cè)試1、根據(jù)單據(jù)測(cè)試和集成測(cè)試兩個(gè)過(guò)程,制定測(cè)試計(jì)劃。按階段設(shè)計(jì)測(cè)試實(shí)例,并將測(cè)試結(jié)果記錄,未通過(guò)的的反饋給開(kāi)發(fā)人員調(diào)整。2、完成測(cè)試文檔、操作手冊(cè)、安裝維護(hù)手冊(cè)的編寫(xiě)。第十一章、用戶(hù)培訓(xùn)1、準(zhǔn)備用戶(hù)培訓(xùn)計(jì)劃、培訓(xùn)手冊(cè)2、確定培訓(xùn)時(shí)間、培訓(xùn)地點(diǎn),向用戶(hù)進(jìn)行系統(tǒng)使用培訓(xùn)、操作指導(dǎo)及提供軟件操作手冊(cè)。3、保留培訓(xùn)簽到表,用戶(hù)意見(jiàn)等存檔。第十二章、系統(tǒng)上線1、制定上線計(jì)劃,確定上線工作時(shí)間表,部署的環(huán)境。2、上線操作步驟以及問(wèn)題處理步驟;3、根據(jù)軟件特點(diǎn)、客戶(hù)需求進(jìn)行軟件部署,并記錄軟件部署和運(yùn)行結(jié)果;4、項(xiàng)目組根據(jù)系統(tǒng)運(yùn)行請(qǐng)款對(duì)系統(tǒng)進(jìn)行優(yōu)化,記錄系統(tǒng)的運(yùn)行情況、系統(tǒng)問(wèn)題和處理后的版本。第十三章、系統(tǒng)驗(yàn)收1、驗(yàn)收工作準(zhǔn)備,按要求整理項(xiàng)目成果物,打印裝訂成冊(cè),并提交客戶(hù)方。2、系統(tǒng)主要使用部門(mén)及信息技術(shù)部門(mén)聯(lián)合成立項(xiàng)目驗(yàn)收小組,從需求功能及技術(shù)需求層面對(duì)系統(tǒng)進(jìn)行綜合評(píng)估和項(xiàng)目成果物的審核,根據(jù)驗(yàn)收情況形成系統(tǒng)驗(yàn)收?qǐng)?bào)告3、應(yīng)用部門(mén)及信息技術(shù)部門(mén)負(fù)責(zé)人根據(jù)系統(tǒng)試運(yùn)行情況簽署驗(yàn)收意見(jiàn)。第十四章、產(chǎn)品維護(hù)1、調(diào)出項(xiàng)目主要開(kāi)發(fā)人員,按照合同要求安排維護(hù)人員對(duì)系統(tǒng)進(jìn)行技術(shù)支持。2、系統(tǒng)需求變更或調(diào)整,記錄變更原因和軟件及源代碼的版本控制,按照軟件變更要求對(duì)系統(tǒng)進(jìn)行維護(hù)。第章十五、源碼和文檔1、源代碼/文檔管理采用版本控制軟件SVN。2、按項(xiàng)目的階段性完成源代碼、文檔的上傳。項(xiàng)目負(fù)責(zé)人每天對(duì)代碼進(jìn)行檢查,開(kāi)發(fā)總監(jiān)或部門(mén)經(jīng)理定期進(jìn)行抽查。3、文檔分為項(xiàng)目文檔和個(gè)人文檔,文檔上傳前進(jìn)行歸類(lèi)和匯總。第十六章、質(zhì)量檢查1、項(xiàng)目負(fù)責(zé)人每天要檢查成員的工作完成情況,特別是新員工的工作進(jìn)展;2、工作抽查制度:不定期的進(jìn)行抽檢,并將檢查對(duì)象、檢查時(shí)間、檢查內(nèi)容、檢查結(jié)果反饋給被抽檢人。3、內(nèi)部審核制度:針對(duì)業(yè)務(wù)需求、概要設(shè)計(jì)(功能界面、數(shù)據(jù)庫(kù))或疑難問(wèn)題組織評(píng)審會(huì),提出意見(jiàn)或解決方案。第十七章、文檔規(guī)范1、需按照軟件實(shí)施的階段落實(shí)成果物,參照《軟件過(guò)程提交成果表》。2、如果客戶(hù)有特殊要求,請(qǐng)按照客戶(hù)要求的規(guī)范完成。并將最終的問(wèn)題提交公司歸檔備份。第十八章、軟件變更為規(guī)范軟件變更與維護(hù)管理,特制定本制度。本制度適用于應(yīng)用系統(tǒng)開(kāi)發(fā)完畢并正式上線,移交給客戶(hù)方之后的運(yùn)行支持及系統(tǒng)變更工作。1、系統(tǒng)變更工作可分為功能完善維護(hù)、系統(tǒng)缺陷修改、統(tǒng)計(jì)報(bào)表生成。2、需求部門(mén)提出系統(tǒng)變更需求,開(kāi)發(fā)部技術(shù)支持人員根據(jù)重要性和緊迫性做判斷,確定其優(yōu)先級(jí)和影響程度,并進(jìn)行相應(yīng)處理,同時(shí)將變更需求整理成系統(tǒng)變更申請(qǐng)表。3、系統(tǒng)變更實(shí)現(xiàn)過(guò)程按照軟件開(kāi)發(fā)過(guò)程規(guī)定進(jìn)行,遵循軟件開(kāi)發(fā)過(guò)程統(tǒng)一的編碼標(biāo)準(zhǔn)和版本控制,并經(jīng)過(guò)測(cè)試通過(guò)才能完成部署和上線。4、在系統(tǒng)變更完成后,開(kāi)發(fā)人員需將系統(tǒng)變更表的執(zhí)行結(jié)果找業(yè)務(wù)部門(mén)負(fù)責(zé)人簽字后,提交至公司進(jìn)行歸檔管理。軟件開(kāi)發(fā)流程規(guī)范V1.0德聯(lián)軟件有限責(zé)任公司編制人:侯秀美審核人:2015年8月19日目錄目錄 一、概述本文制定煙臺(tái)開(kāi)發(fā)區(qū)德聯(lián)軟件有限責(zé)任公司計(jì)算機(jī)軟件開(kāi)發(fā)規(guī)范文檔。本規(guī)范的目的是使公司軟件開(kāi)發(fā)項(xiàng)目階段清晰、要求明確、任務(wù)具體、編寫(xiě)的代碼規(guī)范,使之規(guī)范化、系統(tǒng)化和工程化,向公司內(nèi)從事軟件開(kāi)發(fā)的工程師和管理人員提出一系列規(guī)范和要求,從而有利于開(kāi)發(fā)過(guò)程的控制和管理,提高所開(kāi)發(fā)軟件系統(tǒng)的質(zhì)量,縮短開(kāi)發(fā)時(shí)間,減少開(kāi)發(fā)和維護(hù)費(fèi)用,以保證項(xiàng)目高質(zhì)量、順利進(jìn)行。本規(guī)范包含:開(kāi)發(fā)流程規(guī)范和開(kāi)發(fā)代碼規(guī)范等,開(kāi)發(fā)流程規(guī)范需要技術(shù)開(kāi)發(fā)人員編寫(xiě)相關(guān)內(nèi)容,希望每個(gè)技術(shù)人員形成習(xí)慣,如有新的內(nèi)容更新會(huì)及時(shí)通知大家,如有好的規(guī)范要求也可通知編制人員及時(shí)更新。本規(guī)范為煙臺(tái)開(kāi)發(fā)區(qū)德聯(lián)軟件有限責(zé)任公司內(nèi)部材料,嚴(yán)禁其他商業(yè)應(yīng)用。二、開(kāi)發(fā)流程規(guī)范 接受開(kāi)發(fā)任務(wù),詳細(xì)閱讀軟件技術(shù)規(guī)范或技術(shù)文檔,如對(duì)技術(shù)文檔有疑義或者不清楚的地方及時(shí)與項(xiàng)目總工或用戶(hù)溝通,根據(jù)文檔和溝通內(nèi)容編寫(xiě)項(xiàng)目開(kāi)發(fā)計(jì)劃,必須包括但不限于系統(tǒng)軟硬件開(kāi)發(fā)環(huán)境、系統(tǒng)架構(gòu)、系統(tǒng)功能模塊設(shè)計(jì)、系統(tǒng)功能開(kāi)發(fā)流程圖、開(kāi)發(fā)修改記錄。2.1系統(tǒng)軟硬件開(kāi)發(fā)環(huán)境開(kāi)發(fā)環(huán)境的搭建,最好形成文檔,便于以后同樣工作的使用。開(kāi)發(fā)人員要明確系統(tǒng)開(kāi)發(fā)擬采用的數(shù)據(jù)庫(kù)、操作系統(tǒng)、開(kāi)發(fā)語(yǔ)言、開(kāi)發(fā)工具、服務(wù)器等(具體到版本)。明確整個(gè)系統(tǒng)開(kāi)發(fā)工作流程,至少應(yīng)該包括以下流程。2.2系統(tǒng)架構(gòu)(系統(tǒng)組成)確定系統(tǒng)整體體系架構(gòu),各層次之間的數(shù)據(jù)流的連接,確定軟件服務(wù)器的硬件配置及用戶(hù)硬件資源配置,確定與用戶(hù)軟件平臺(tái)的統(tǒng)一協(xié)調(diào)。開(kāi)發(fā)人員在繪制架構(gòu)圖時(shí)給出基本框架,能反映出基本意義即可,可以直接用文字代替例子中的圖片。圖1系統(tǒng)邏輯架構(gòu)圖舉例圖2物理架構(gòu)圖舉例2.3系統(tǒng)功能模塊設(shè)計(jì)給出系統(tǒng)的主要功能模塊,每個(gè)模塊所包含的功能。圖3圖書(shū)管理系統(tǒng)模塊規(guī)劃圖舉例2.4系統(tǒng)功能開(kāi)發(fā)流程圖給出系統(tǒng)主要功能的業(yè)務(wù)流程圖。圖4系統(tǒng)功能業(yè)務(wù)流程圖舉例2.5開(kāi)發(fā)修改記錄1.開(kāi)發(fā)代碼做好備份(可以在完成一個(gè)重大功能之后,或者按時(shí)間周期性進(jìn)行備份),以免由于不可抗力導(dǎo)致代碼不可修復(fù)。2.在每次重大修改之后要做好記錄(改動(dòng)的具體細(xì)節(jié)),修改前的版本要及時(shí)備份,可以方面隨時(shí)還原系統(tǒng)。修改日期修改內(nèi)容是否備份備注

三、開(kāi)發(fā)代碼規(guī)范 在研究項(xiàng)目團(tuán)隊(duì)協(xié)作開(kāi)發(fā)的情況下(這里的團(tuán)隊(duì)協(xié)作也適合于應(yīng)用項(xiàng)目的開(kāi)發(fā)),編程時(shí)應(yīng)該強(qiáng)調(diào)的一個(gè)重要方面是程序的易讀性,在保證軟件速度等性能指標(biāo)能滿(mǎn)足用戶(hù)需求的情況下,能讓其他程序員容易讀懂你所編寫(xiě)的程序。若研究項(xiàng)目小組的所有開(kāi)發(fā)人員都遵循統(tǒng)一的、鮮明的一套編程風(fēng)格,可以讓協(xié)作者、后繼者和自己一目了然,在很短的時(shí)間內(nèi)看清楚程序結(jié)構(gòu),理解設(shè)計(jì)的思路,大大提高代碼的可讀性、可重用性、程序健壯性、可移植性、可維護(hù)性。 制定本編程規(guī)范的目的是為了提高軟件開(kāi)發(fā)效率及所開(kāi)發(fā)軟件的可維護(hù)性,提高軟件的質(zhì)量。本規(guī)范由程序風(fēng)格、命名規(guī)范、注釋規(guī)范、程序健壯性、可移植性、錯(cuò)誤處理以及軟件的模塊化規(guī)范等部分組成。 此規(guī)范以C/C++程序設(shè)計(jì)討論。3.1文件結(jié)構(gòu) 每個(gè)C++/C程序通常分為兩個(gè)文件。一個(gè)文件用于保存程序的聲明(declaration),稱(chēng)為頭文件。另一個(gè)文件用于保存程序的實(shí)現(xiàn)(implementation),稱(chēng)為定義(definition)文件。 C++/C程序的頭文件以“.h”為后綴,C程序的定義文件以“.c”為后綴,C++程序的定義文件通常以“.cpp”為后綴(也有一些系統(tǒng)以“.cc”或“.cxx”為后綴)。3.1.1文件信息聲明文件信息聲明位于頭文件和定義文件的開(kāi)頭(參見(jiàn)示例3-1),主要內(nèi)容有:(1)

版權(quán)信息;(2)

文件名稱(chēng),項(xiàng)目代碼,摘要,參考文獻(xiàn);(3)

當(dāng)前版本號(hào),作者/修改者,完成日期;(4)

版本歷史信息;(5)

主要函數(shù)描述。

//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////Copyright(c)2015,DeLianSoftCompanyYanTai//Allrightsreserved.////Filename:filename.h//ProjectCode:Theprojectcodeaboutthisfile//Abstract:Describethecontentofthisfilesummarily//Reference:////Version:1.1//Author:thenameofauthor(mender)//Accomplisheddate:September2,2004////Replacedversion:1.0//OriginalAuthor:thenameoforiginalauthor(mender)//Accomplisheddate:September10,2003////Mainfunctions:// Function1Returncode Functionname(ParameterExplain)// Function2Returncode Functionname(ParameterExplain)// ...// FunctionnReturncode Functionname(ParameterExplain)////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////示例3-1文件信息聲明☆

【規(guī)則3.1-1】 文件信息聲明以?xún)尚行备荛_(kāi)始,以?xún)尚行备芙Y(jié)束,每一行都以?xún)蓚€(gè)斜杠開(kāi)始;☆

【規(guī)則3.1-2】 文件信息聲明包含五個(gè)部分,各部分之間以一空行間隔;☆

【規(guī)則3.1-3】 在主要函數(shù)部分描述了文件所包含的主要函數(shù)的聲明信息,如果是頭文件,這一部分是可以省略的。3.1.2頭文件的結(jié)構(gòu)頭文件由三部分內(nèi)容組成:(1)

頭文件開(kāi)頭處的文件信息聲明(參見(jiàn)示例3-1);(2)

預(yù)處理塊;(3)

函數(shù)和類(lèi)結(jié)構(gòu)聲明等。假設(shè)頭文件名稱(chēng)為filesystem.h,頭文件的結(jié)構(gòu)參見(jiàn)示例3-2。☆

【規(guī)則3.2-1】 為了防止頭文件被重復(fù)引用,應(yīng)當(dāng)用ifndef/define/endif結(jié)構(gòu)產(chǎn)生預(yù)處理塊;“#ifndef”或者“#define”后以TAB鍵代替SPACE鍵做空格;如果頭文件名稱(chēng)是由多個(gè)單詞組成,則各單詞間以下劃線“_”連接,例如有頭文件名稱(chēng)為“filesystem.h”,則定義如下:“#ifndef _FILE_SYSTEM_H_”;☆

【規(guī)則3.2-2】 用#include<filename.h>格式來(lái)引用標(biāo)準(zhǔn)庫(kù)的頭文件(編譯器將從標(biāo)準(zhǔn)庫(kù)目錄開(kāi)始搜索);☆

【規(guī)則3.2-3】 用#include“filename.h”格式來(lái)引用非標(biāo)準(zhǔn)庫(kù)的頭文件(編譯器將從用戶(hù)的工作目錄開(kāi)始搜索);☆

【建議3.2-1】 頭文件中只存放“聲明”而不存放“定義”;☆

【建議3.2-1】 頭文件中應(yīng)包含所有定義文件所定義的函數(shù)聲明,如果一個(gè)頭文件對(duì)應(yīng)多個(gè)定義文件,則不同定義文件內(nèi)實(shí)現(xiàn)的函數(shù)要分開(kāi)聲明,并作注釋以解釋所聲明的函數(shù)從屬于那一個(gè)定義文件;☆

【建議3.2-3】 宏定義和函數(shù)聲明分離,在兩個(gè)頭文件中定義,如果沒(méi)有類(lèi)成員函數(shù),可以將類(lèi)和結(jié)構(gòu)的定義與函數(shù)聲明分離,也就是說(shuō)一個(gè)頭文件專(zhuān)用于宏定義,一個(gè)頭文件專(zhuān)用于類(lèi)和結(jié)構(gòu)的定義,一個(gè)頭文件專(zhuān)用于函數(shù)聲明;☆

【建議3.2-4】 在C++語(yǔ)法中,類(lèi)的成員函數(shù)可以在聲明的同時(shí)被定義,并且自動(dòng)成為內(nèi)聯(lián)函數(shù)。這雖然會(huì)帶來(lái)書(shū)寫(xiě)上的方便,但卻造成了風(fēng)格不一致,弊大于利。建議將成員函數(shù)的定義與聲明分開(kāi),不論該函數(shù)體有多么小。頭文件的結(jié)構(gòu)如下://文件信息聲明見(jiàn)示例3-1,此處省略。

#ifndef _FILE_SYSTEM_H_ //avoidreferencingthefilefilesystem.hrepeat#define _FILE_SYSTEM_H_#include<math.h> //referencestandardheadfile…#include“myheader.h” //referencenon-standardheadfile…voidFunction1(…); //globalfunctiondeclare…classCBox //classstructuredecalre{…};#endif示例3-2C++/C頭文件的結(jié)構(gòu)

3.1.3定義文件的結(jié)構(gòu)定義文件有三部分內(nèi)容:(1)

定義文件開(kāi)頭處的文件信息聲明(參見(jiàn)示例3-1);(2)

對(duì)一些頭文件的引用;(3)

程序的實(shí)現(xiàn)體(包括數(shù)據(jù)和代碼)。假設(shè)定義文件的名稱(chēng)為filesystem.c,定義文件的結(jié)構(gòu)參見(jiàn)示例3-3。//文件信息聲明見(jiàn)示例3-1,此處省略。

#include“filesystem.h” //referenceaheadfile…//globalfunctionrealizationvoidFunction1(…){…}

//classmemberfunctionrealizationvoidCBox::Draw(…){…}示例3-3C++/C定義文件的結(jié)構(gòu)3.1.4頭文件的作用 早期的編程語(yǔ)言如Basic、Fortran沒(méi)有頭文件的概念,C++/C語(yǔ)言的初學(xué)者雖然會(huì)用使用頭文件,但常常不明其理。這里對(duì)頭文件的作用略作解釋?zhuān)?(1)通過(guò)頭文件來(lái)調(diào)用庫(kù)功能。在很多場(chǎng)合,源代碼不便(或不準(zhǔn))向用戶(hù)公布,只要向用戶(hù)提供頭文件和二進(jìn)制的庫(kù)即可。用戶(hù)只需要按照頭文件中的接口聲明來(lái)調(diào)用庫(kù)功能,而不必關(guān)心接口怎么實(shí)現(xiàn)的。編譯器會(huì)從庫(kù)中提取相應(yīng)的代碼; (2)頭文件能加強(qiáng)類(lèi)型安全檢查。如果某個(gè)接口被實(shí)現(xiàn)或被使用時(shí),其方式與頭文件中的聲明不一致,編譯器就會(huì)指出錯(cuò)誤,這一簡(jiǎn)單的規(guī)則能大大減輕程序員調(diào)試、改錯(cuò)的負(fù)擔(dān)。3.1.5目錄結(jié)構(gòu) 如果一個(gè)軟件的頭文件數(shù)目比較多(如超過(guò)十個(gè)),通常應(yīng)將頭文件和定義文件分別保存于不同的目錄,以便于維護(hù)。 例如可將頭文件保存于include目錄,將定義文件保存于source目錄(可以是多級(jí)目錄)。如果某些頭文件是私有的,它不會(huì)被用戶(hù)的程序直接引用,則沒(méi)有必要公開(kāi)其“聲明”。為了加強(qiáng)信息隱藏,這些私有的頭文件可以和定義文件存放于同一個(gè)目錄。3.2命名規(guī)則 比較著名的命名規(guī)則當(dāng)推“匈牙利”命名法,該命名規(guī)則的主要思想是“在變量和函數(shù)名中加入前綴以增進(jìn)人們對(duì)程序的理解”。例如所有的字符變量均以ch為前綴,若是指針變量則追加前綴p。如果一個(gè)變量由ppch開(kāi)頭,則表明它是指向字符指針的指針。 “匈牙利”法最大的缺點(diǎn)是煩瑣,例如 inti,j,k; floatx,y,z; 倘若采用“匈牙利”命名規(guī)則,則應(yīng)當(dāng)寫(xiě)成 intiI,iJ,ik;//前綴i表示int類(lèi)型 floatfX,fY,fZ;//前綴f表示float類(lèi)型 如此煩瑣的程序會(huì)讓絕大多數(shù)程序員無(wú)法忍受。 總的說(shuō)來(lái),沒(méi)有一種命名規(guī)則可以讓所有的程序員贊同,且命名規(guī)則對(duì)軟件產(chǎn)品而言并不是“成敗悠關(guān)”的事,而且在不同的平臺(tái)和不同的環(huán)境下編寫(xiě)的程序所應(yīng)遵循的規(guī)則也不盡相同,所以我們只是追求制定一種令大多數(shù)項(xiàng)目成員滿(mǎn)意的命名規(guī)則,并在項(xiàng)目中貫徹實(shí)施。3.2.1共性原則本節(jié)論述的共性規(guī)則是被大多數(shù)程序員采納的,我們應(yīng)當(dāng)在遵循這些共性規(guī)則的前提下,再擴(kuò)充特定的規(guī)則,如3.2.2節(jié)☆

【規(guī)則3.2.1-1】 標(biāo)識(shí)符應(yīng)當(dāng)直觀且可以拼讀,可望文知意,不必進(jìn)行“解碼”;☆

【規(guī)則3.2.1-2】 標(biāo)識(shí)符的長(zhǎng)度應(yīng)當(dāng)符合“min-length&&max-information”原則;☆

【規(guī)則3.2.1-3】 命名規(guī)則盡量與所采用的操作系統(tǒng)或開(kāi)發(fā)工具的風(fēng)格保持一致;☆

【規(guī)則3.2.1-4】 程序中不要出現(xiàn)僅靠大小寫(xiě)區(qū)分的相似的標(biāo)識(shí)符?!?/p>

【規(guī)則3.2.1-5】 程序中不要出現(xiàn)標(biāo)識(shí)符完全相同的局部變量和全局變量,盡管兩者的作用域不同而不會(huì)發(fā)生語(yǔ)法錯(cuò)誤,但會(huì)使人誤解;☆

【規(guī)則3.2.1-6】 變量的名字應(yīng)當(dāng)使用“名詞”或者“形容詞+名詞”;☆

【規(guī)則3.2.1-7】 全局函數(shù)的名字應(yīng)當(dāng)使用“動(dòng)詞”或者“動(dòng)詞+名詞”(動(dòng)賓詞組);☆

【規(guī)則3.2.1-8】 用正確的反義詞組命名具有互斥意義的變量或相反動(dòng)作的函數(shù)等;☆

【建議3.2.1-9】 盡量避免名字中出現(xiàn)數(shù)字編號(hào),如Value1,Value2等,除非邏輯上的確需要編號(hào);注:3.2.1

標(biāo)識(shí)符最好采用英文單詞或其組合,便于記憶和閱讀,切忌使用漢語(yǔ)拼音來(lái)命名,程序中的英文單詞一般不要太復(fù)雜,用詞應(yīng)當(dāng)準(zhǔn)確,例如不要把CurrentValue寫(xiě)成NowValue;3.2.2

標(biāo)示符的長(zhǎng)度應(yīng)當(dāng)以最小的長(zhǎng)度實(shí)現(xiàn)最多信息,一般來(lái)說(shuō),長(zhǎng)名字能更好地表達(dá)含義,但并非長(zhǎng)的變量名就一定要比短的變量名要好,此外單字符的名字也是有用的,常見(jiàn)的如i,j,k,m,n,x,y,z等,它們通??捎米骱瘮?shù)內(nèi)的局部變量;3.2.3

不同的操作系統(tǒng)的程序設(shè)計(jì)風(fēng)格是不一樣的,例如Windows應(yīng)用程序的標(biāo)識(shí)符通常采用“大小寫(xiě)”混排的方式,如AddChild,而Unix應(yīng)用程序的標(biāo)識(shí)符通常采用“小寫(xiě)加下劃線”的方式,如add_child,別把這兩類(lèi)風(fēng)格混在一起使用;3.2.2Windows變量命名規(guī)則☆

【規(guī)則3.2.2-1】 變量的命名規(guī)則要求采用“匈牙利法則”,即開(kāi)頭字母用變量的類(lèi)型,其余部分用變量的英文意思或其英文意思的縮寫(xiě),盡量避免采用中文拼音,要求單詞的第一個(gè)字母大寫(xiě);即:變量名=變量類(lèi)型+變量英文意思(或縮寫(xiě))變量類(lèi)型請(qǐng)參見(jiàn)附表1-變量類(lèi)型表;☆

【規(guī)則3.2.2-2】 類(lèi)名和函數(shù)名用大寫(xiě)字母開(kāi)頭的單詞組合而成;對(duì)struct、union、class變量的命名要求定義的類(lèi)型用大寫(xiě),結(jié)構(gòu)采用S開(kāi)頭,聯(lián)合體采用U開(kāi)頭,類(lèi)采用C開(kāi)頭;例如:structSPoint{ int m_nX; int m_nY;};unionURecordLen{ BYTE m_byRecordNum; BYTE m_byRecordLen;} classCNode { //類(lèi)成員變量或成員函數(shù) };☆

【規(guī)則3.2.2-3】 指針變量命名的基本原則為:一重指針變量的基本原則為: 變量名=“p”+變量類(lèi)型前綴+命名對(duì)多重指針變量的基本原則為:二重指針:變量名=“pp”+變量類(lèi)型前綴+命名三重指針: 變量名=“ppp”+變量類(lèi)型前綴+命名例如一個(gè)short*型的變量應(yīng)該表示為pnStart;☆

【規(guī)則3.2.2-4】 全局變量用g_開(kāi)頭;例如一個(gè)全局的長(zhǎng)型變量定義為g_lFileNum,即:變量名=g_+變量類(lèi)型+變量的英文意思(或縮寫(xiě));☆

【規(guī)則3.2.2-5】 靜態(tài)變量采用s_開(kāi)頭;例如一個(gè)靜態(tài)的指針變量定義為s_plPrevInst,即:變量名=s_+變量類(lèi)型+變量的英文意思(或縮寫(xiě));☆

【規(guī)則3.2.2-6】 類(lèi)成員變量采用m_開(kāi)頭;例如一個(gè)長(zhǎng)型成員變量定義為m_lCount,即:變量名=m_+變量類(lèi)型+變量的英文意思(或縮寫(xiě));☆

【規(guī)則3.2.2-7】 對(duì)const的變量要求在變量的命名規(guī)則前加入c_(若作為函數(shù)的輸入?yún)?shù),可以不加),即:變量名=c_+變量命名規(guī)則,例如:constchar*c_szFileName;☆

【規(guī)則3.2.2-8】 對(duì)枚舉類(lèi)型(enum)中的變量,要求用枚舉變量或其縮寫(xiě)做前綴,且用下劃線隔離變量名,所有枚舉類(lèi)型都要用大寫(xiě),例如:enum EMDAYS{ EMDAYS_MONDAY; EMDAYS_TUESDAY; };☆

【規(guī)則3.2.2-9】 對(duì)常量(包括錯(cuò)誤的編碼)命名,要求常量名用大寫(xiě),常量名用英文意思表示其意思,用下劃線分割單詞,例如:#define CM_7816_OK 0x9000;☆

【規(guī)則3.2.2-10】 為了防止某一軟件庫(kù)中的一些標(biāo)識(shí)符和其它軟件庫(kù)中的沖突,可以為各種標(biāo)識(shí)符加上能反映軟件性質(zhì)的前綴。例如三維圖形標(biāo)準(zhǔn)OpenGL的所有庫(kù)函數(shù)均以gl開(kāi)頭,所有常量(或宏定義)均以GL開(kāi)頭。3.3程序風(fēng)格程序風(fēng)格雖然不會(huì)影響程序的功能,但會(huì)影響程序的可讀性,追求清晰、美觀,是程序風(fēng)格的重要構(gòu)成因素。3.3.1空行空行起著分隔程序段落的作用??招械皿w(不過(guò)多也不過(guò)少)將使程序的布局更加清晰。空行不會(huì)浪費(fèi)內(nèi)存,雖然打印含有空行的程序是會(huì)多消耗一些紙張,但是值得?!?/p>

【規(guī)則3.3.1-1】 在每個(gè)類(lèi)聲明之后、每個(gè)函數(shù)定義結(jié)束之后都要加空行。參見(jiàn)示例3.3.1(a);☆

【規(guī)則3.3.1-2】 在一個(gè)函數(shù)體內(nèi),邏揖上密切相關(guān)的語(yǔ)句之間不加空行,其它地方應(yīng)加空行分隔。參見(jiàn)示例3.3.1(b);

//blanklinevoidFunction1(…){…}//blanklinevoidFunction2(…){…}//blanklinevoidFunction3(…){…}

//blanklinewhile(condition){ statement1; //blankline if(condition) { statement2; } else { statement3; }//blankline statement4;}示例3.3.1(a)函數(shù)之間的空行示例3.3.1(b)函數(shù)內(nèi)部的空行

3.3.2代碼行☆

【規(guī)則3.3.2-1】 一行代碼只做一件事情,如只定義一個(gè)變量,或只寫(xiě)一條語(yǔ)句,這樣的代碼容易閱讀,并且方便于寫(xiě)注釋?zhuān)弧?/p>

【規(guī)則3.3.2-2】 if、for、while、do等語(yǔ)句自占一行,執(zhí)行語(yǔ)句不得緊跟其后,不論執(zhí)行語(yǔ)句有多少都要加{},這樣可以防止書(shū)寫(xiě)失誤;☆

【規(guī)則3.3.2-3】 if、for、while、do等語(yǔ)句的“{”要單獨(dú)占用一行;☆

【建議3.3.2-1】 所有函數(shù)內(nèi)的變量都在函數(shù)開(kāi)始處定義;☆

【建議3.3.2-2】 盡可能在定義變量的同時(shí)初始化該變量(就近原則),如果變量的引用處和其定義處相隔比較遠(yuǎn),變量的初始化很容易被忘記。如果引用了未被初始化的變量,可能會(huì)導(dǎo)致程序錯(cuò)誤,本建議可以減少隱患。示例3.3.2(a)為風(fēng)格良好的代碼行,示例3.3.2(b)為風(fēng)格不良的代碼行。

intnWidth; //widthintnHeight; //heightintnDepth; //depth

intnWidth,nHight,nDepth;//width,height,depth

x=a+b;y=c+d;z=e+f;X=a+b;y=c+d;z=e+f;

if(nWidth<nHight){ DoSomething();}if(nWidth<nHight)DoSomething();for(initialization;condition;update){DoSomething();}//blanklineOther();

for(initialization;condition;update)DoSomething();Other();

示例3.3.2(a)風(fēng)格良好的代碼行示例3.3.2(b)風(fēng)格不良的代碼行3.3.3代碼行內(nèi)的空格☆

【規(guī)則3.3.3-1】 關(guān)鍵字之后要留空格,象const、virtual、inline、case等關(guān)鍵字之后至少要留一個(gè)空格,否則無(wú)法辨析關(guān)鍵字,象if、for、while等關(guān)鍵字之后應(yīng)留一個(gè)空格再跟左括號(hào)‘(’,以突出關(guān)鍵字;☆

【規(guī)則3.3.3-2】 函數(shù)名之后不要留空格,緊跟左括號(hào)‘(’,以與關(guān)鍵字區(qū)別;☆

【規(guī)則3.3.3-3】 ‘(’向后緊跟,‘)’、‘,’、‘;’向前緊跟,緊跟處不留空格;☆

【規(guī)則3.3.3-4】 ‘,’之后要留空格,如Function(x,y,z),如果‘;’不是一行的結(jié)束符號(hào),其后要留空格,如for(initialization;condition;update);☆

【規(guī)則3.3.3-5】 賦值操作符、比較操作符、算術(shù)操作符、邏輯操作符、位域操作符,如“=”、“+=”“>=”、“<=”、“+”、“*”、“%”、“&&”、“||”、“<<”,“^”等二元操作符的前后應(yīng)當(dāng)加空格;☆

【規(guī)則3.3.3-6】 一元操作符如“!”、“~”、“++”、“--”、“&”(地址運(yùn)算符)等前后不加空格;☆

【規(guī)則3.3.3-7】 象“[]”、“.”、“->”這類(lèi)操作符前后不加空格;☆

【建議3.3.3-1】 對(duì)于表達(dá)式比較長(zhǎng)的for語(yǔ)句和if語(yǔ)句,為了緊湊起見(jiàn)可以適當(dāng)?shù)厝サ粢恍┛崭瘢鏵or(i=0;i<10;i++)和if((a<=b)&&(c<=d))

voidFunc1(intx,inty,intz);//favorablestylevoidFunc1(intx,inty,intz);//illstyleif(year>=2000)//favorablestyleif(year>=2000)//illstyleif((a>=b)&&(c<=d))//favorablestyleif(a>=b&&c<=d)//illstylefor(i=0;i<10;i++)//favorablestylefor(i=0;i<10;i++)//illstylefor(i=0;I<10;i++)//favorablestylex=a<b?a:b;//favorablestylex=a<b?a:b;//illstyleint*x=&y;//favorablestyleint*x=&y;//illstylearray[5]=0;//Donotusearray[5]=0;a.Function();//Donotusea.Function();b->Function();//Donotuseb->Function();

示例3.3.3代碼行內(nèi)的空格

3.3.4對(duì)齊☆

【規(guī)則3.3.4-1】 程序的分界符‘{’和‘}’應(yīng)獨(dú)占一行并且位于同一列,同時(shí)與引用它們的語(yǔ)句左對(duì)齊;☆

【規(guī)則3.3.4-2】 {}之內(nèi)的代碼塊在‘{’右邊數(shù)格處左對(duì)齊;☆

【規(guī)則3.3.4.3】 代碼的的對(duì)齊采用TAB鍵而不采用空格鍵對(duì)齊,一般TAB鍵設(shè)置為向后空4個(gè)空格。

示例3.3.4(a)為風(fēng)格良好的對(duì)齊,示例3.3.4(b)為風(fēng)格不良的對(duì)齊。

voidFunction(intx){…//programcode}

voidFunction(intx){…//programcode}

if(condition){…//programcode}else{…//programcode}if(condition){…//programcode}else{…//programcode}for(initialization;condition;update){…//programcode}for(initialization;condition;update){…//programcode}While(condition){…//programcode}while(condition){…//programcode}如果出現(xiàn)嵌套的{},則使用縮進(jìn)對(duì)齊,如: { … { … } …}

示例3.3.4(a)風(fēng)格良好的對(duì)齊示例3.3.4(b)風(fēng)格不良的對(duì)齊3.3.5長(zhǎng)行拆分☆

【規(guī)則3.3.5-1】 代碼行最大長(zhǎng)度宜控制在70至80個(gè)字符以?xún)?nèi);☆

【規(guī)則3.3.5-2】 長(zhǎng)表達(dá)式要在低優(yōu)先級(jí)操作符處拆分成新行,操作符放在新行之首(以便突出操作符),拆分出的新行要進(jìn)行適當(dāng)?shù)目s進(jìn),使排版整齊,語(yǔ)句可讀。

if((very_longer_variable1>=very_longer_variable12)&&(very_longer_variable3<=very_longer_variable14)&&(very_longer_variable5<=very_longer_variable16)){DoSomething();}virtualCMatrixCMultiplyMatrix(CMatrixleftMatrix,CMatrixrightMatrix);

for(very_longer_initialization; very_longer_condition; very_longer_update){ DoSomething();}示例3.3.5長(zhǎng)行的拆分3.3.6修飾符的位置修飾符*和&應(yīng)該靠近數(shù)據(jù)類(lèi)型還是該靠近變量名,是個(gè)有爭(zhēng)議的活題,若將修飾符*靠近數(shù)據(jù)類(lèi)型,例如:int*x;從語(yǔ)義上講此寫(xiě)法比較直觀,即x是int類(lèi)型的指針,上述寫(xiě)法的弊端是容易引起誤解,例如:int*x,y;此處y容易被誤解為指針變量。雖然將x和y分行定義可以避免誤解,但并不是人人都愿意這樣做。☆

【規(guī)則3.3.6-1】 應(yīng)當(dāng)將修飾符*和&緊靠變量名;3.3.7注釋C語(yǔ)言的注釋符為“/*…*/”。C++語(yǔ)言中,程序塊的注釋常采用“/*…*/”,行注釋一般采用“//…”。注釋通常用于:(1)版本、版權(quán)聲明;(2)函數(shù)接口說(shuō)明;(3)重要的代碼行或段落提示。雖然注釋有助于理解代碼,但注意不可過(guò)多地使用注釋。參見(jiàn)示例3.3.7。

【規(guī)則3.3.7-1】 注釋是對(duì)代碼的“提示”,而不是文檔,程序中的注釋不可喧賓奪主,注釋太多了會(huì)讓人眼花繚亂,注釋的花樣要少;☆

【規(guī)則3.3.7-2】 如果代碼本來(lái)就是清楚的,則不必加注釋?zhuān)焕鏸++; //i加1,多余的注釋☆

【規(guī)則3.3.7-3】 邊寫(xiě)代碼邊注釋?zhuān)薷拇a同時(shí)修改相應(yīng)的注釋?zhuān)员WC注釋與代碼的一致性,不再有用的注釋要?jiǎng)h除;☆

【規(guī)則3.3.7-4】 注釋?xiě)?yīng)當(dāng)準(zhǔn)確、易懂,防止注釋有二義性,錯(cuò)誤的注釋不但無(wú)益反而有害;☆

【規(guī)則3.3.7-5】 盡量避免在注釋中使用縮寫(xiě),特別是不常用縮寫(xiě);☆

【規(guī)則3.3.7-6】 注釋的位置應(yīng)與被描述的代碼相鄰,可以放在代碼的上方或右方,不可放在下方;☆

【規(guī)則3.3.7-8】 當(dāng)代碼比較長(zhǎng),特別是有多重嵌套時(shí),應(yīng)當(dāng)在一些段落的結(jié)束處加注釋?zhuān)阌陂喿x;☆

【建議3.3.7-9】 對(duì)于多行代碼的注釋?zhuān)M量不采用“/*...*/”,而采用多行“//”注釋?zhuān)@樣雖然麻煩,但是在做屏蔽調(diào)試時(shí)不用查找配對(duì)的“/*...*/”。

//////////////////////////////////////////////////////////////////////Functioncapacity://Parameterdeclare://Returnvalue:////////////////////////////////////////////////////////////////////voidFunction(floatx,floaty,floatz){…}

if(…){…while(…){…}//endofwhile…}//endofif示例3.3.7程序的注釋3.7.1文件頭的注釋 文件頭的注釋請(qǐng)參見(jiàn)3.1,文件頭的注釋是以?xún)尚行备荛_(kāi)始,以?xún)尚行备芙Y(jié)束(以區(qū)別于函數(shù)的注釋)。3.7.2函數(shù)頭的注釋一般說(shuō)來(lái)每個(gè)函數(shù)都應(yīng)該做詳細(xì)的注釋?zhuān)瘮?shù)頭的注釋是以一行斜杠開(kāi)始,以一行斜杠結(jié)束,注釋的內(nèi)容包括“功能”,“參數(shù)”,“返回值”,“設(shè)計(jì)思想”,“調(diào)用函數(shù)”,“日期”,“修改記錄”等幾個(gè)方面,函數(shù)頭的注釋格式如下:////////////////////////////////////////////////////////////////////////////////////////////////Functioncapacity: Describethefunctioncapacity//Parameterdeclare:// parameter1: Describethefunctionofparameter(input/outputparameter)// parameter2: Describethefunctionofparameter(input/outputparameter)// //Returnvalue:Describethepossiblereturnvalue//Designedidea:Describedesignedideaaboutthefunction//Author: //Creationdate:Creationdate(YY-MM-DD)//Transferredfunction: Listthesub-functioninthefunction//Modificationrecord:// (一)Mender1: Modifieddate: modifiedcontent//////////////////////////////////////////////////////////////////////////////////////////////

3.4函數(shù)設(shè)計(jì) 函數(shù)是C++/C程序的基本功能單元,其重要性不言而喻。函數(shù)設(shè)計(jì)的細(xì)微缺點(diǎn)很容易導(dǎo)致該函數(shù)被錯(cuò)用,所以光使函數(shù)的功能正確是不夠的。本章重點(diǎn)論述函數(shù)的接口設(shè)計(jì)和內(nèi)部實(shí)現(xiàn)的一些規(guī)則。 函數(shù)接口的兩個(gè)要素是參數(shù)和返回值。C語(yǔ)言中,函數(shù)的參數(shù)和返回值的傳遞方式有兩種:值傳遞(passbyvalue)和指針傳遞(passbypointer)。C++語(yǔ)言中多了引用傳遞(passbyreference)。由于引用傳遞的性質(zhì)象指針傳遞,而使用方式卻象值傳遞,初學(xué)者常常迷惑不解,容易引起混亂,請(qǐng)先閱讀3.4.6節(jié)“引用與指針的比較”。3.4.1參數(shù)的規(guī)則☆

【規(guī)則3.4.1-1】 參數(shù)的書(shū)寫(xiě)要完整,不要貪圖省事只寫(xiě)參數(shù)的類(lèi)型而省略參數(shù)名字,如果函數(shù)沒(méi)有參數(shù),則用void填充;例如:voidSetValue(intnWidth,intnHeight); //良好的風(fēng)格voidSetValue(int,int); //不良的風(fēng)格floatGetValue(void); //良好的風(fēng)格floatGetValue(); //不良的風(fēng)格☆

【規(guī)則3.4.1-2】 參數(shù)命名要恰當(dāng),順序要合理;例如編寫(xiě)字符串拷貝函數(shù)StringCopy,它有兩個(gè)參數(shù),如果把參數(shù) 名字起為str1和str2,例如:voidStringCopy(char*str1,char*str2);那么我們很難搞清楚究竟是把str1拷貝到str2中,還是剛好倒過(guò)來(lái),可以把參數(shù)名字起得更有意義,如叫strSource和strDestination。這樣從名字上就可以看出應(yīng)該把strSource拷貝到strDestination。還有一個(gè)問(wèn)題,這兩個(gè)參數(shù)那一個(gè)該在前那一個(gè)該在后?參數(shù)的順序要遵循程序員的習(xí)慣。一般地,應(yīng)將目的參數(shù)放在前面,源參數(shù)放在后面。如果將函數(shù)聲明為:voidStringCopy(char*strSource,char*strDestination);別人在使用時(shí)可能會(huì)不假思索地寫(xiě)成如下形式:charstr[20];StringCopy(str,“HelloWorld”); //參數(shù)順序顛倒

【規(guī)則3.4.1-3】 如果參數(shù)是指針,且僅作輸入用,則應(yīng)在類(lèi)型前加const,以防止該指針在函數(shù)體內(nèi)被意外修改。例如:voidStringCopy(char*strDestination,constchar*strSource);☆

【規(guī)則3.4.1-4】 如果輸入?yún)?shù)以值傳遞的方式傳遞對(duì)象,則宜改用“const&”方式來(lái)傳遞,這樣可以省去臨時(shí)對(duì)象的構(gòu)造和析構(gòu)過(guò)程,從而提高效率;☆

【建議3.4.1-1】 避免函數(shù)有太多的參數(shù),參數(shù)個(gè)數(shù)盡量控制在5個(gè)以?xún)?nèi)。如果參數(shù)太多,在使用時(shí)容易將參數(shù)類(lèi)型或順序搞錯(cuò);☆

【建議3.4.1-2】 盡量不要使用類(lèi)型和數(shù)目不確定的參數(shù);C標(biāo)準(zhǔn)庫(kù)函數(shù)printf是采用不確定參數(shù)的典型代表,其原型為:intprintf(constchat*format[,argument]…);這種風(fēng)格的函數(shù)在編譯時(shí)喪失了嚴(yán)格的類(lèi)型安全檢查。3.4.2返回值的規(guī)則☆

【規(guī)則3.4.2-1】 不要省略返回值的類(lèi)型;C語(yǔ)言中,凡不加類(lèi)型說(shuō)明的函數(shù),一律自動(dòng)按整型處理,這樣做不會(huì)有什么好處,卻容易被誤解為void類(lèi)型;C++語(yǔ)言有很?chē)?yán)格的類(lèi)型安全檢查,不允許上述情況發(fā)生。由于C++程序可以調(diào)用C函數(shù),為了避免混亂,規(guī)定任何C++/C函數(shù)都必須有類(lèi)型。如果函數(shù)沒(méi)有返回值,那么應(yīng)聲明為void類(lèi)型☆

【規(guī)則3.4.2-2】 函數(shù)名字與返回值類(lèi)型在語(yǔ)義上不可沖突;違反這條規(guī)則的典型代表是C標(biāo)準(zhǔn)庫(kù)函數(shù)getchar。例如:charc;c=getchar();if(c==EOF)…按照getchar名字的意思,將變量c聲明為char類(lèi)型是很自然的事情。但不幸的是getchar的確不是char類(lèi)型,而是int類(lèi)型,其原型如下:intgetchar(void);由于c是char類(lèi)型,取值范圍是[-128,127],如果宏EOF的值在char的取值范圍之外,那么if語(yǔ)句將總是失敗,這種“危險(xiǎn)”人們一般哪里料得到!導(dǎo)致本例錯(cuò)誤的責(zé)任并不在用戶(hù),是函數(shù)getchar誤導(dǎo)了使用者☆

【規(guī)則3.4.2-3】 不要將正常值和錯(cuò)誤標(biāo)志混在一起返回。正常值用輸出參數(shù)獲得,而錯(cuò)誤標(biāo)志用return語(yǔ)句返回;☆

【建議3.4.2-1】 有時(shí)候函數(shù)原本不需要返回值,但為了增加靈活性如支持鏈?zhǔn)奖磉_(dá),可以附加返回值;例如字符串拷貝函數(shù)strcpy的原型:char*strcpy(char*strDest,constchar*strSrc);strcpy函數(shù)將strSrc拷貝至輸出參數(shù)strDest中,同時(shí)函數(shù)的返回值又是strDest。這樣做并非多此一舉,可以獲得如下靈活性:charstr[20];intnLength=strlen(strcpy(str,“HelloWorld”));☆

【建議3.4.2-2】 如果函數(shù)的返回值是一個(gè)對(duì)象,有些場(chǎng)合用“引用傳遞”替換“值傳遞”可以提高效率。而有些場(chǎng)合只能用“值傳遞”而不能用“引用傳遞”,否則會(huì)出錯(cuò);對(duì)于建議3.4.2-2,如果函數(shù)的返回值是一個(gè)對(duì)象,有些場(chǎng)合用“引用傳遞”替換“值傳遞”可以提高效率,而有些場(chǎng)合只能用“值傳遞”而不能用“引用傳遞”,否則會(huì)出錯(cuò),例如:classString{… //賦值函數(shù) String&operate=(constString&other); //相加函數(shù),如果沒(méi)有friend修飾則只許有一個(gè)右側(cè)參數(shù)friend Stringoperate+(constString&s1,constString&s2);private: char*m_data;};String的賦值函數(shù)operate=的實(shí)現(xiàn)如下:String&String::operate=(constString&other){ if(this==&other) return*this; deletem_data; m_data=newchar[strlen(other.data)+1]; strcpy(m_data,other.data); return*this; //返回的是*this的引用,無(wú)需拷貝過(guò)程}對(duì)于賦值函數(shù),應(yīng)當(dāng)用“引用傳遞”的方式返回String對(duì)象。如果用“值傳遞”的方式,雖然功能仍然正確,但由于return語(yǔ)句要把*this拷貝到保存返回值的外部存儲(chǔ)單元之中,增加了不必要的開(kāi)銷(xiāo),降低了賦值函數(shù)的效率。例如: Stringa,b,c; … a=b; //如果用“值傳遞”,將產(chǎn)生一次*this拷貝 a=b=c; //如果用“值傳遞”,將產(chǎn)生兩次*this拷貝

String的相加函數(shù)operate+的實(shí)現(xiàn)如下:Stringoperate+(constString&s1,constString&s2){ Stringtemp; deletetemp.data; //temp.data是僅含‘\0’的字符串 temp.data=newchar[strlen(s1.data)+strlen(s2.data)+1]; strcpy(temp.data,s1.data); strcat(temp.data,s2.data); returntemp; }

對(duì)于相加函數(shù),應(yīng)當(dāng)用“值傳遞”的方式返回String對(duì)象。如果改用“引用傳遞”,那么函數(shù)返回值是一個(gè)指向局部對(duì)象temp的“引用”。由于temp在函數(shù)結(jié)束時(shí)被自動(dòng)銷(xiāo)毀,將導(dǎo)致返回的“引用”無(wú)效。例如: c=a+b;此時(shí)a+b并不返回期望值,c什么也得不到,流下了隱患。3.4.3函數(shù)內(nèi)部實(shí)現(xiàn)的規(guī)則不同功能的函數(shù)其內(nèi)部實(shí)現(xiàn)各不相同,看起來(lái)似乎無(wú)法就“內(nèi)部實(shí)現(xiàn)”達(dá)成一致的觀點(diǎn)。但根據(jù)經(jīng)驗(yàn),我們可以在函數(shù)體的“入口處”和“出口處”從嚴(yán)把關(guān),從而提高函數(shù)的質(zhì)量。

【規(guī)則3.4.3-1】 在函數(shù)體的“入口處”,對(duì)參數(shù)的有效性進(jìn)行檢查;很多程序錯(cuò)誤是由非法參數(shù)引起的,我們應(yīng)該充分理解并正確使用“斷言”(assert)來(lái)防止此類(lèi)錯(cuò)誤。詳見(jiàn)4.5節(jié)“使用斷言”☆

【規(guī)則3.4.3-2】 在函數(shù)體的“出口處”,對(duì)return語(yǔ)句的正確性和效率進(jìn)行檢查;注意事項(xiàng)如下:(1)

return語(yǔ)句不可返回指向“棧內(nèi)存”的“指針”或者“引用”,因?yàn)樵搩?nèi)存在函數(shù)體結(jié)束時(shí)被自動(dòng)銷(xiāo)毀,例如: char*Func(void) { charstr[]=“helloworld”; //str的內(nèi)存位于棧上 … returnstr; //將導(dǎo)致錯(cuò)誤 }(2)

要搞清楚返回的究竟是“值”、“指針”還是“引用”;(3)

如果函數(shù)返回值是一個(gè)對(duì)象,要考慮return語(yǔ)句的效率,例如: returnString(s1+s2);這是臨時(shí)對(duì)象的語(yǔ)法,表示“創(chuàng)建一個(gè)臨時(shí)對(duì)象并返回它”,不要以為它與“先創(chuàng)建一個(gè)局部對(duì)象temp并返回它的結(jié)果”是等價(jià)的,如 Stringtemp(s1+s2); returntemp;實(shí)質(zhì)不然,上述代碼將發(fā)生三件事。 首先,temp對(duì)象被創(chuàng)建,同時(shí)完成初始化; 然后拷貝構(gòu)造函數(shù)把temp拷貝到保存返回值的外部存儲(chǔ)單元中; 最后,temp在函數(shù)結(jié)束時(shí)被銷(xiāo)毀(調(diào)用析構(gòu)函數(shù))。然而“創(chuàng)建一個(gè)臨時(shí)對(duì)象并返回它”的過(guò)程是不同的,編譯器直接把臨時(shí)對(duì)象創(chuàng)建并初始化在外部存儲(chǔ)單元中,省去了拷貝和析構(gòu)的化費(fèi),提高了效率。類(lèi)似地,我們不要將 returnint(x+y); //創(chuàng)建一個(gè)臨時(shí)變量并返回它寫(xiě)成 inttemp=x+y; returntemp;由于內(nèi)部數(shù)據(jù)類(lèi)型如int,float,double的變量不存在構(gòu)造函數(shù)與析構(gòu)函數(shù),雖然該“臨時(shí)變量的語(yǔ)法”不會(huì)提高多少效率,但是程序更加簡(jiǎn)潔易讀。3.4.4其它建議☆

【建議3.4.4-1】 函數(shù)的功能要單一,不要設(shè)計(jì)多用途的函數(shù);☆

【建議3.4.4-2】 函數(shù)體的規(guī)模要小,盡量控制在150行代碼之內(nèi);☆

【建議3.4.4-3】 盡量避免函數(shù)帶有“記憶”功能。相同的輸入應(yīng)當(dāng)產(chǎn)生相同的輸出帶有“記憶”功能的函數(shù),其行為可能是不可預(yù)測(cè)的,因?yàn)樗男袨榭赡苋Q于某種“記憶狀態(tài)”。這樣的函數(shù)既不易理解又不利于測(cè)試和維護(hù)。在C/C++語(yǔ)言中,函數(shù)的static局部變量是函數(shù)的“記憶”存儲(chǔ)器。建議盡量少用static局部變量,除非必需?!?/p>

【建議3.4.4-4】 不僅要檢查輸入?yún)?shù)的有效性,還要檢查通過(guò)其它途徑進(jìn)入函數(shù)體內(nèi)的變量的有效性,例如全局變量、文件句柄等;☆

【建議3.4.4-5】 用于出錯(cuò)處理的返回值一定要清楚,讓使用者不容易忽視或誤解錯(cuò)誤情況。3.4.5使用斷言程序一般分為Debug版本和Release版本,Debug版本用于內(nèi)部調(diào)試,Release版本發(fā)行給用戶(hù)使用。斷言assert是僅在Debug版本起作用的宏,它用于檢查“不應(yīng)該”發(fā)生的情況。示例4.5是一個(gè)內(nèi)存復(fù)制函數(shù)。在運(yùn)行過(guò)程中,如果assert的參數(shù)為假,那么程序就會(huì)中止(一般地還會(huì)出現(xiàn)提示對(duì)話,說(shuō)明在什么地方引發(fā)了assert)。

void*memcpy(void*pvTo,constvoid*pvFrom,size_tsize){ assert((pvTo!=NULL)&&(pvFrom!=NULL)); //使用斷言 byte*pbTo=(byte*)pvTo; //防止改變pvTo的地址 byte*pbFrom=(byte*)pvFrom; //防止改變pvFrom的地址 while(size-->0) *pbTo++=*pbFrom++; returnpvTo;}示例3.4.5復(fù)制不重疊的內(nèi)存塊

assert不是一個(gè)倉(cāng)促拼湊起來(lái)的宏。為了不在程序的Debug版本和Release版本引起差別,assert不應(yīng)該產(chǎn)生任何副作用。所以assert不是函數(shù),而是宏。程序員可以把a(bǔ)ssert看成一個(gè)在任何系統(tǒng)狀態(tài)下都可以安全使用的無(wú)害測(cè)試手段。如果程序在assert處終止了,并不是說(shuō)含有該assert的函數(shù)有錯(cuò)誤,而是調(diào)用者出了差錯(cuò),assert可以幫助我們找到發(fā)生錯(cuò)誤的原因。

【規(guī)則3.4.5-1】 使用斷言捕捉不應(yīng)該發(fā)生的非法情況,不要混淆非法情況與錯(cuò)誤情況之間的區(qū)別,后者是必然存在的并且是一定要作出處理的;☆

【規(guī)則3.4.5-2】 在函數(shù)的入口處,使用斷言檢查參數(shù)的有效性(合法性);☆

【建議3.4.5-1】 在編寫(xiě)函數(shù)時(shí),要進(jìn)行反復(fù)的考查,并且自問(wèn):“我打算做哪些假定?”一旦確定了的假定,就要使用斷言對(duì)假定進(jìn)行檢查;☆

【建議3.4.5-2】 一般教科書(shū)都鼓勵(lì)程序員們進(jìn)行防錯(cuò)設(shè)計(jì),但要記住這種編程風(fēng)格可能會(huì)隱瞞錯(cuò)誤。當(dāng)進(jìn)行防錯(cuò)設(shè)計(jì)時(shí),如果“不可能發(fā)生”的事情的確發(fā)生了,則要使用斷言進(jìn)行報(bào)警。3.4.6引用與指針的比較引用是C++中的概念,初學(xué)者容易把引用和指針混淆一起。一下程序中,n是m的一個(gè)引用(reference),m是被引用物(referent)。 intm; int&n=m;n相當(dāng)于m的別名(綽號(hào)),對(duì)n的任何操作就是對(duì)m的操作。所以n既不是m的拷貝,也不是指向m的指針,其實(shí)n就是m它自己。引用的一些規(guī)則如下:(1)

引用被創(chuàng)建的同時(shí)必須被初始化(指針則可以在任何時(shí)候被初始化);(2)

不能有NULL引用,引用必須與合法的存儲(chǔ)單元關(guān)聯(lián)(指針則可以是NULL);(3)

一旦引用被初始化,就不能改變引用的關(guān)系(指針則可以隨時(shí)改變所指的對(duì)象)。 以下示例程序中,k被初始化為i的引用。語(yǔ)句k=j并不能將k修改成為j的引用,只是把k的值改變成為6。由于k是i的引用,所以i的值也變成了6。 inti=5; intj=6; int&k=i; k=j; //k和i的值都變成了6; 上面的程序看起來(lái)象在玩文字游戲,沒(méi)有體現(xiàn)出引用的價(jià)值。引用的主要功能是傳遞函數(shù)的參數(shù)和返回值。C++語(yǔ)言中,函數(shù)的參數(shù)和返回值的傳遞方式有三種:值傳遞、指針傳遞和引用傳遞。 以下是“值傳遞”的示例程序。由于Func1函數(shù)體內(nèi)的x是外部變量n的一份拷貝,改變x的值不會(huì)影響n,所以n的值仍然是0。 voidFunc1(intx){ x=x+10;}…intn=0; Func1(n); cout<<“n=”<<n<<endl; //n=0 以下是“指針傳遞”的示例程序。由于Func2函數(shù)體內(nèi)的x是指向外部變量n的指針,改變?cè)撝羔樀膬?nèi)容將導(dǎo)致n的值改變,所以n的值成為10。 voidFunc2(int*x){ (*x)=(*x)+10;}…intn=0; Func2(&n); cout<<“n=”<<n<<endl; //n=10

以下是“引用傳遞”的示例程序。由于Func3函數(shù)體內(nèi)的x是外部變量n的引用,x和n是同一個(gè)東西,改變x等于改變n,所以n的值成為10。 voidFunc3(int&x){ x=x+10;}…intn=0; Func3(n); cout

溫馨提示

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

最新文檔

評(píng)論

0/150

提交評(píng)論