前言
這篇重點介紹一下代碼編程的注釋風格和注釋文檔生成工具
注釋的原則是有助于對程序的閱讀理解以及提供二次開發所需文檔,注釋的方式有很多,但是業內常用的規范是 Doxygen 代碼注釋規范。遵循原則為,說明性文件、函數接口必須充分注釋說明。全局變量需要說明功能及取值范圍,需要自行處理資料函數需要加上使用警告信息。
注意:
- 不要使用注釋來屏蔽代碼。
- 關于函數和局部變量的注釋,當代碼已經可自注釋時,不用添加多余的注釋。
簡介
Doxygen 規范簡要的說,Doxygen 注釋塊其實就是在C、C++注釋塊的基礎添加一些額外標識,使 Doxygen 把它識別出來, 并將它通過對應得工具生成的說明文檔。
文件注釋
文件注釋通常放在整個文件開頭,如說明文件名、作者、日期、描述或版本等諸多信息,具體參數 Doxygen 的文件注釋風格。
1/**
2 * @file 文件名
3 * @brief 簡介
4 * @details 細節
5 * @mainpage 工程概覽
6 * @author 作者
7 * @email 郵箱
8 * @version 版本號
9 * @date 年-月-日
10 * @license 版權
11 */
我常用的風格如下:
1/**
2 **********************************************************************************************************************
3 * @file adcDrive.c
4 * @author const-zpc
5 * @date 2020-7-20
6 * @brief 該文件提供ADC驅動功能,以管理ADC驅動的以下功能:
7 * + 初始化
8 * + ADC數據
9 *
10 **********************************************************************************************************************
11 * @attention
12 * 暫無
13 *
14 **********************************************************************************************************************
15 */
類/結構體注釋
類或者結構體定義的注釋方式非常簡單,使用@brief
后面填寫類的概述,換行填寫類的詳細信息
/**
* @brief CAN發送幀類型結構體定義.
*/
typedef struct {
uint32_t id; /*!< 幀的標識符ID */
CAN_IdTypeDef emIdType;/*!< 幀的類型 */
CAN_RtrTypeDef emRtrType;/*!< 幀的格式 */
uint8_t lenth; /*!< 幀的數據長度 */
uint8_t data[8]; /*!< 幀的數據內容 */
} CAN_TxFrameType;
枚舉注釋
/**
* @brief CAN使能/禁止枚舉定義
*/
typedef enum{
CAN_DISABLE = 0, /*!< (0)禁止 */
CAN_ENABLE = !CAN_DISABLE/*!< (1)使能 */
}CAN_EnableTypeDef;
/**
* @brief CAN幀的格式枚舉定義.
*/
typedef enum {
CAN_DATA_FRAME = 0, /*!< (0)數據幀 */
CAN_REMOTE_FRAME /*!< (1)遠程幀 */
} CAN_RtrTypeDef;
函數
1/**
2 * @brief 讀取指定CAN接收幀的數據信息.
3 *
4 * @note 建議先調用函數...
5 * @param[in] rxIndex g_arrtCANRxFrameInfo 的索引值
6 * @param[in,out] pData - CAN幀數據內容指針.
7 * @param[out] pLength - CAN幀數據長度.
8 * @retval 數據長度
9 */
10int CAN_ReadRxFrameInfo(uint16_t rxIndex, uint8_t *pData, uint8_t *pLength)
11{
12 ...
13}
文檔生成軟件
Doxygen 能將程序中的特定批注轉換成為說明文檔。他可以依據程序本身的結構,將程序中按規范注釋的批注經過處理生成一個純粹的參考手冊,通過提取代碼結構或借助自動生成的包含依賴圖、繼承圖以及協作圖來可視化文檔之間的關系,Doxygen生成的幫助文檔的格式可以是 CHM、RTF、PostScript、PDF、HTML等。
Doxygen是一種開源跨平臺的,以類似JavaDoc風格描述的文檔系統,完全支持 C、C++、Java、Objective-C 和 IDL 語言,部分支持 PHP、C#。注釋的語法與 Qt-Doc、Kdoc 和 JavaDoc 兼容。Doxygen 可以從一套歸檔源文件開始,生成HTML格式的在線類瀏覽器,或離線LATE、RTF參考手冊。
軟件截圖
根據上述定義的注釋通過工具生成文檔部分截圖:
-
代碼
+關注
關注
30文章
4825瀏覽量
69041 -
注釋
+關注
關注
0文章
11瀏覽量
6544 -
全局變量
+關注
關注
1文章
28瀏覽量
9002
發布評論請先 登錄
相關推薦
評論