日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術(shù)文章
文章詳情頁

PHP Document 代碼注釋規(guī)范

瀏覽:27日期:2024-01-11 09:07:31

PHPDocumentor是一個(gè)用PHP寫的工具,對于有規(guī)范注釋的php程序,它能夠快速生成具有相互參照,索引等功能的API文檔。老的版本是 phpdoc。

1. 什么是phpDocumentor ?PHPDocumentor是一個(gè)用PHP寫的工具,對于有規(guī)范注釋的php程序,它能夠快速生成具有相互參照,索引等功能的API文檔。老的版本是 phpdoc,從1.3.0開始,更名為phpDocumentor,新的版本加上了對php5語法的支持,同時(shí),可以通過在客戶端瀏覽器上操作生成文檔,文檔可以轉(zhuǎn)換為PDF,HTML,CHM幾種形式,非常的方便。PHPDocumentor工作時(shí),會(huì)掃描指定目錄下面的php源代碼,掃描其中的關(guān)鍵字,截取需要分析的注釋,然后分析注釋中的專用的tag,生成 xml文件,接著根據(jù)已經(jīng)分析完的類和模塊的信息,建立相應(yīng)的索引,生成xml文件,對于生成的xml文件,使用定制的模板輸出為指定格式的文件。2. 安裝phpDocumentor和其他pear下的模塊一樣,phpDocumentor的安裝也分為自動(dòng)安裝和手動(dòng)安裝兩種方式,兩種方式都非常方便:a. 通過pear 自動(dòng)安裝在命令行下輸入pear install PhpDocumentorb. 手動(dòng)安裝在http://manual.phpdoc.org/下載最新版本的PhpDocumentor(現(xiàn)在是1.4.0),把內(nèi)容解壓即可。3.怎樣使用PhpDocumentor生成文檔命令行方式:在phpDocumentor所在目錄下,輸入Php –h會(huì)得到一個(gè)詳細(xì)的參數(shù)表,其中幾個(gè)重要的參數(shù)如下:-f 要進(jìn)行分析的文件名,多個(gè)文件用逗號隔開-d 要分析的目錄,多個(gè)目錄用逗號分割-t 生成的文檔的存放路徑-o 輸出的文檔格式,結(jié)構(gòu)為輸出格式:轉(zhuǎn)換器名:模板目錄。例如:phpdoc -o HTML:frames:earthli -f test.php -t docsWeb界面生成在新的phpdoc中,除了在命令行下生成文檔外,還可以在客戶端瀏覽器上操作生成文檔,具體方法是先把PhpDocumentor的內(nèi)容放在apache目錄下使得通過瀏覽器可以訪問到,訪問后顯示如下的界面:點(diǎn)擊files按鈕,選擇要處理的php文件或文件夾,還可以通過該指定該界面下的Files to ignore來忽略對某些文件的處理。然后點(diǎn)擊output按鈕來選擇生成文檔的存放路徑和格式.最后點(diǎn)擊create,phpdocumentor就會(huì)自動(dòng)開始生成文檔了,最下方會(huì)顯示生成的進(jìn)度及狀態(tài),如果成功,會(huì)顯示Total Documentation Time: 1 secondsdoneOperation Completed!!然后,我們就可以通過查看生成的文檔了,如果是pdf格式的,名字默認(rèn)為documentation.pdf。4.給php代碼添加規(guī)范的注釋PHPDocument是從你的源代碼的注釋中生成文檔,因此在給你的程序做注釋的過程,也就是你編制文檔的過程。從這一點(diǎn)上講,PHPdoc促使你要養(yǎng)成良好的編程習(xí)慣,盡量使用規(guī)范,清晰文字為你的程序做注釋,同時(shí)多多少少也避免了事后編制文檔和文檔的更新不同步的一些問題。在phpdocumentor中,注釋分為文檔性注釋和非文檔性注釋。所謂文檔性注釋,是那些放在特定關(guān)鍵字前面的多行注釋,特定關(guān)鍵字是指能夠被phpdoc分析的關(guān)鍵字,例如class,var等,具體的可參加附錄1.那些沒有在關(guān)鍵字前面或者不規(guī)范的注釋就稱作非文檔性注釋,這些注釋將不會(huì)被phpdoc所分析,也不會(huì)出現(xiàn)在你產(chǎn)生的api文當(dāng)中。3.2如何書寫文檔性注釋:所有的文檔性注釋都是由/**開始的一個(gè)多行注釋,在phpDocumentor里稱為DocBlock, DocBlock是指軟件開發(fā)人員編寫的關(guān)于某個(gè)關(guān)鍵字的幫助信息,使得其他人能夠通過它知道這個(gè)關(guān)鍵字的具體用途,如何使用。 PhpDocumentor規(guī)定一個(gè)DocBlock包含如下信息:1. 功能簡述區(qū)2. 詳細(xì)說明區(qū)3. 標(biāo)記tag文檔性注釋的第一行是功能描述區(qū),正文一般是簡明扼要地說明這個(gè)類,方法或者函數(shù)的功能,功能簡述的正文在生成的文檔中將顯示在索引區(qū)。功能描述區(qū)的內(nèi)容可以通過一個(gè)空行或者 . 來結(jié)束在功能描述區(qū)后是一個(gè)空行,接著是詳細(xì)說明區(qū),. 這部分主要是詳細(xì)說明你的API的功能,用途,如果可能,也可以有用法舉例等等。在這部分,你應(yīng)該著重闡明你的API函數(shù)或者方法的通常的用途,用法,并且指明是否是跨平臺(tái)的(如果涉及到),對于和平臺(tái)相關(guān)的信息,你要和那些通用的信息區(qū)別對待,通常的做法是另起一行,然后寫出在某個(gè)特定平臺(tái)上的注意事項(xiàng)或者是特別的信息,這些信息應(yīng)該足夠,以便你的讀者能夠編寫相應(yīng)的測試信息,比如邊界條件,參數(shù)范圍,斷點(diǎn)等等。之后同樣是一個(gè)空白行,然后是文檔的標(biāo)記tag,指明一些技術(shù)上的信息,主要是最主要的是調(diào)用參數(shù)類型,返回值極其類型,繼承關(guān)系,相關(guān)方法/函數(shù)等等。關(guān)于文檔標(biāo)記,詳細(xì)的請參考第四節(jié):文檔標(biāo)記。文檔注釋中還可以使用例如<b> <code>這樣的標(biāo)簽,詳細(xì)介紹請參考附錄二。下面是一個(gè)文檔注釋的例子

/*** 函數(shù)add,實(shí)現(xiàn)兩個(gè)數(shù)的加法** 一個(gè)簡單的加法計(jì)算,函數(shù)接受兩個(gè)數(shù)a、b,返回他們的和c** @param int 加數(shù)* @param int 被加數(shù)* @return integer*/function Add($a, $b) {return $a+$b;}

生成文檔如下:Addinteger Add( int $a, int $b)[line 45]函數(shù)add,實(shí)現(xiàn)兩個(gè)數(shù)的加法Constants 一個(gè)簡單的加法計(jì)算,函數(shù)接受兩個(gè)數(shù)a、b,返回他們的和cParameters• int $a - 加數(shù)• int $b - 被加數(shù)5.文檔標(biāo)記:文檔標(biāo)記的使用范圍是指該標(biāo)記可以用來修飾的關(guān)鍵字,或其他文檔標(biāo)記。所有的文檔標(biāo)記都是在每一行的 * 后面以@開頭。如果在一段話的中間出來@的標(biāo)記,這個(gè)標(biāo)記將會(huì)被當(dāng)做普通內(nèi)容而被忽略掉。@access使用范圍:class,function,var,define,module該標(biāo)記用于指明關(guān)鍵字的存取權(quán)限:private、public或proteced@author指明作者@copyright使用范圍:class,function,var,define,module,use指明版權(quán)信息@deprecated使用范圍:class,function,var,define,module,constent,global,include指明不用或者廢棄的關(guān)鍵字@example該標(biāo)記用于解析一段文件內(nèi)容,并將他們高亮顯示。Phpdoc會(huì)試圖從該標(biāo)記給的文件路徑中讀取文件內(nèi)容@const使用范圍:define用來指明php中define的常量@final使用范圍:class,function,var指明關(guān)鍵字是一個(gè)最終的類、方法、屬性,禁止派生、修改。@filesource和example類似,只不過該標(biāo)記將直接讀取當(dāng)前解析的php文件的內(nèi)容并顯示。@global指明在此函數(shù)中引用的全局變量@ingore用于在文檔中忽略指定的關(guān)鍵字@license相當(dāng)于html標(biāo)簽中的<a>,首先是URL,接著是要顯示的內(nèi)容例如<a href=”http://www.baidu.com”>百度</a>可以寫作 @license http://www.baidu.com 百度@link類似于license但還可以通過link指到文檔中的任何一個(gè)關(guān)鍵字@name為關(guān)鍵字指定一個(gè)別名。@package使用范圍:頁面級別的-> define,function,include類級別的->class,var,methods用于邏輯上將一個(gè)或幾個(gè)關(guān)鍵字分到一組。@abstrcut說明當(dāng)前類是一個(gè)抽象類@param指明一個(gè)函數(shù)的參數(shù)@return指明一個(gè)方法或函數(shù)的返回指@static指明關(guān)建字是靜態(tài)的。@var指明變量類型@version指明版本信息@todo指明應(yīng)該改進(jìn)或沒有實(shí)現(xiàn)的地方@throws指明此函數(shù)可能拋出的錯(cuò)誤異常,極其發(fā)生的情況上面提到過,普通的文檔標(biāo)記標(biāo)記必須在每行的開頭以@標(biāo)記,除此之外,還有一種標(biāo)記叫做inline tag,用{@}表示,具體包括以下幾種:{@link}用法同@link{@source}顯示一段函數(shù)或方法的內(nèi)容6.一些注釋規(guī)范a.注釋必須是/*** XXXXXXX*/的形式b.對于引用了全局變量的函數(shù),必須使用glboal標(biāo)記。c.對于變量,必須用var標(biāo)記其類型(int,string,bool...)d.函數(shù)必須通過param和return標(biāo)記指明其參數(shù)和返回值e.對于出現(xiàn)兩次或兩次以上的關(guān)鍵字,要通過ingore忽略掉多余的,只保留一個(gè)即可f.調(diào)用了其他函數(shù)或類的地方,要使用link或其他標(biāo)記鏈接到相應(yīng)的部分,便于文檔的閱讀。g.必要的地方使用非文檔性注釋,提高代碼易讀性。h.描述性內(nèi)容盡量簡明扼要,盡可能使用短語而非句子。i.全局變量,靜態(tài)變量和常量必須用相應(yīng)標(biāo)記說明7. 總結(jié)phpDocumentor是一個(gè)非常強(qiáng)大的文檔自動(dòng)生成工具,利用它可以幫助我們編寫規(guī)范的注釋,生成易于理解,結(jié)構(gòu)清晰的文檔,對我們的代碼升級,維護(hù),移交等都有非常大的幫助。關(guān)于phpDocumentor更為詳細(xì)的說明,可以到它的官方網(wǎng)站http://manual.phpdoc.org/查閱8.附錄附錄1:能夠被phpdoc識(shí)別的關(guān)鍵字:IncludeRequireinclude_oncerequire_oncedefinefunctionglobalclass附錄2文檔中可以使用的標(biāo)簽<b><code><br><kdb><li><pre><ul><samp><var>附錄三:一段含有規(guī)范注釋的php代碼 :

<?php/*** Sample File 2, phpDocumentor Quickstart** This file demonstrates the rich information that can be included in* in-code documentation through DocBlocks and tags.* @author Greg Beaver <cellog@php.net>* @version 1.0* @package sample*/// sample file #1/*** Dummy include value, to demonstrate the parsing power of phpDocumentor*/include_once 'sample3.php';/*** Special global variable declaration DocBlock* @global integer $GLOBALS['_myvar']* @name $_myvar*/$GLOBALS['_myvar'] = 6;/*** Constants*//*** first constant*/define('testing', 6);/*** second constant*/define('anotherconstant', strlen('hello'));/*** A sample function docblock* @global string document the fact that this function uses $_myvar* @staticvar integer $staticvar this is actually what is returned* @param string $param1 name to declare* @param string $param2 value of the name* @return integer*/function firstFunc($param1, $param2 = 'optional') {static $staticvar = 7;global $_myvar;return $staticvar;}/*** The first example class, this is in the same package as the* procedural stuff in the start of the file* @package sample* @subpackage classes*/class myclass {/*** A sample private variable, this can be hidden with the --parseprivate* option* @accessprivate* @var integer|string*/var $firstvar = 6;/*** @link http://www.example.com Example link* @see myclass()* @uses testing, anotherconstant* @var array*/var $secondvar =array( 'stuff' => array( 6, 17, 'armadillo' ), testing => anotherconstant);/*** Constructor sets up {@link $firstvar}*/function myclass() {$this->firstvar = 7;}/*** Return a thingie based on $paramie* @param boolean $paramie* @return integer|babyclass*/function parentfunc($paramie) {if ($paramie) {return 6;} else {return new babyclass;}}}/*** @package sample1*/class babyclass extends myclass {/*** The answer to Life, the Universe and Everything* @var integer*/var $secondvar = 42;/*** Configuration values* @var array*/var $thirdvar;/*** Calls parent constructor, then increments {@link $firstvar}*/function babyclass() {parent::myclass();$this->firstvar++;}/*** This always returns a myclass* @param ignored $paramie* @return myclass*/function parentfunc($paramie) {return new myclass;}}?>

標(biāo)簽: PHP
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
国产精品极品在线观看| 日韩福利视频网| 卡一精品卡二卡三网站乱码| 国产欧美午夜| 国产精品3区| 久久精品女人| 国产suv精品一区二区四区视频| 日韩毛片网站| 亚洲免费观看| 男人天堂欧美日韩| 亚洲v天堂v手机在线| 日本一区二区三区视频在线看| 久久不卡日韩美女| 国产精品a久久久久| 精品国产乱码久久久| 日韩综合精品| 久久久水蜜桃av免费网站| 久久久一二三| 石原莉奈一区二区三区在线观看| 你懂的网址国产 欧美| 国产精品最新| 久久尤物视频| 日韩免费高清| 国产精品普通话对白| 日本亚洲欧洲无免费码在线| 国产精品v日韩精品v欧美精品网站 | 精品女同一区二区三区在线观看| 国产高清一区| 亚洲欧美日韩高清在线| 亚洲欧美视频| 欧美在线观看天堂一区二区三区| 欧美91福利在线观看| 亚洲欧美日本视频在线观看| 亚洲精品无吗| 久久精品国产999大香线蕉| 日本久久精品| 国产综合激情| 日本中文字幕视频一区| 久久的色偷偷| 国产精品av一区二区| 亚洲网址在线观看| 久久69成人| 亚洲成人一区| 国产人成精品一区二区三| 中文字幕在线官网| 丝袜美腿高跟呻吟高潮一区| 久久不卡国产精品一区二区| 欧美亚洲精品在线| 日韩国产一二三区| 久久久久久网| 三级在线观看一区二区| 国产福利91精品一区二区| 亚洲色诱最新| 欧美国产先锋| 亚洲精品888| 美女久久久久久 | 国产精品一区二区99| 麻豆国产精品| 国产精品美女久久久| 久久天堂影院| 免费高清在线一区| 欧美激情另类| 亚洲色图国产| 亚洲一区资源| 久久精品xxxxx| 欧美特黄一区| 精品欧美视频| 日韩av不卡一区二区| 欧美sss在线视频| 欧美日本不卡| 亚洲一区二区三区免费在线观看| 国产毛片久久| 精品午夜av| 亚洲丝袜啪啪| 在线日韩欧美| 91亚洲国产| 日韩欧美三区| 播放一区二区| 国产伦精品一区二区三区视频 | 亚洲福利国产| 国产精品亚洲产品| 免费在线视频一区| 免费日韩成人| 日韩欧美中文字幕在线视频| 91久久视频| 色爱av综合网| 日本久久黄色| 九九99久久精品在免费线bt| 日韩精品亚洲一区二区三区免费| 久久精品国产网站| 国产精品普通话对白| 国产福利片在线观看| 国产精品毛片久久久| 亚洲精品黄色| av不卡在线看| 午夜国产一区二区| 亚洲精品在线影院| 精品不卡一区| 欧美黄色一区| 国产欧美日韩一区二区三区在线| 综合日韩av| 国产精品亚洲综合在线观看| 亚洲一区二区日韩| 黄色成人精品网站| 999国产精品视频| 国产黄大片在线观看| 国产精品99精品一区二区三区∴| 久久久噜噜噜| 久久精品日韩欧美| 国产精品久久久久久久久免费高清| 高潮一区二区| 久久精品资源| 精品黄色一级片| 国产极品一区| 国产精品天天看天天狠| 日本在线视频一区二区| 综合一区二区三区| 视频精品一区二区| 男人的天堂亚洲一区| 午夜在线精品| 亚洲一区网站| 久久福利影视| 精品黄色一级片| 日本精品在线播放| 日韩福利在线观看| 国产在线|日韩| 欧美日本二区| 国产精品久久久久久久久久10秀| 欧产日产国产精品视频| 精品久久99| 超级白嫩亚洲国产第一| 久久伊人亚洲| 不卡专区在线| 久久国产精品成人免费观看的软件| 婷婷精品在线观看| 亚洲免费观看高清完整版在线观| 亚洲国产欧美日本视频| 精品国产a一区二区三区v免费| 亚洲一区欧美激情| 噜噜噜躁狠狠躁狠狠精品视频| 国产精品网在线观看| 四虎4545www国产精品 | 99视频精品全部免费在线视频| 亚洲精一区二区三区| 久久亚洲精品伦理| 麻豆91精品91久久久的内涵| 久久久久久网| 91精品99| 丝袜诱惑制服诱惑色一区在线观看| 欧美aa在线观看| 精品国产欧美日韩| 日韩在线综合| 宅男噜噜噜66国产日韩在线观看| 正在播放日韩精品| 97久久亚洲| 精品国产欧美日韩一区二区三区| 日韩精品午夜视频| 国产美女视频一区二区| 麻豆一区二区三| 亚洲a一区二区三区| 日韩精品一二区| 国产欧美一区| 秋霞影院一区二区三区| 日韩一级精品| 日韩av不卡在线观看| 日韩成人精品一区| 91国语精品自产拍| 日韩不卡一区二区三区| 国产一区二区三区亚洲| 欧美在线亚洲| 国产精品一区二区av交换| 欧美日韩尤物久久| 亚洲欧洲国产精品一区| 精品资源在线| 亚洲在线国产日韩欧美| 国产精品1区在线| 偷拍欧美精品| 欧美国产极品| 尤物网精品视频| 国产无遮挡裸体免费久久| 日韩欧美午夜| 日韩精选在线| 精品国产黄a∨片高清在线| 在线国产一区| 麻豆精品久久| 美女久久一区| 国产拍在线视频| 日韩精品欧美精品| 久久九九国产| 国产精品欧美在线观看| 欧美影院三区| 国产精品美女在线观看直播| 欧美日韩国产探花| 久久久久免费| av中文字幕在线观看第一页| 国产一区二区精品福利地址| 亚洲涩涩av| 色爱av综合网| 欧美日韩 国产精品| 欧美天堂亚洲电影院在线观看|