青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

勤能補拙,Expter

成都游戲Coder,記錄游戲開發過程的筆記和心得!

轉:doxygen 使用簡介(C,C++為代碼作注釋)

 如果打算使用doxygen為代碼產生文檔,在編寫代碼時首先要為代碼添加doxygen風格的注釋,這些doxygen風格的注釋可以稱為文檔塊,添加注釋的這個動作可以稱為文檔化代碼。Doxygen會根據相應的doxygen注釋塊為代碼生成相應的文檔。

    對每個代碼條目,doxygen有兩種(在某些情況下可以3種)類型的說明,共同組成文檔:簡要說明和詳細說明,對應方法和函數可以有第三種風格的注釋,函數體內注釋。

    簡要說明只有一行長,詳細說明可以有多行。

 
注釋風格
詳細注釋可以有如下風格

1、JavaDoc風格的注釋,這種風格的注釋是在C風格的注釋塊開始處有兩個 “ * “,如下:

/**
 * ... 注釋塊 ...
 */

2、可以采用QT風格的注釋,這種風格的注釋是在C風格的注釋塊開始處“ * “后面緊跟”!”,如下:

/*!
 * ... 注釋塊 ...
 */

以上兩個例子中 text前的 “ * “ 是可選的,可以寫成

/**
 ... 注釋塊 ...
*/



/*!
... 注釋 ...
*/

3、單行注釋也可以采用如下方式

///
/// ... 注釋 ...
///



//!
//!... 注釋 ...
//!

4、如下注釋也是可以的

/********************************************//**
 *  ... 注釋
 ***********************************************/

或者

/////////////////////////////////////////////////
/// ...注釋...
/////////////////////////////////////////////////
簡要說明有如下格式

1、              使用\brief 命令指定簡要說明,簡要說明以”.” 結束,詳細說明在接下來的一個空行后開始,如下:

/*! \brief 簡要說明.
 *         簡要說明續.
 *
 *  詳細說明(上面要留一個空行).
 */

如果配置文件中把 JAVADOC_AUTOBRIEF  設置成 YES,則可以使用JavaDoc風格注釋塊, 這種風格的注釋,簡要說明自動從“*“后開始 ,直到第一個”.”號結束,例如:

/** 簡要說明.
 *  詳細說明.
 */

多行C++風格注釋:

/// 簡要說明.
/// 詳細說明.

3、可以采用如下注釋:

/// 簡要說明.
/** 詳細說明. */

或者

//! 簡要說明.

//! 詳細 (上面的空行是需要的)
//! 說明.

   上例中間空行用來分隔簡要說明和詳細說明的。請注意下面格式的注釋是不合法的,doxygen只允許一條詳細說明對應一條簡要說明:

//!簡潔描述信息
//! 詳細描述信息
/*! 注意,又一詳細描述信息!
 */

    如果一個代碼項的聲明和定義之前都有簡要說明,則doxygen只使用聲明之前的說明。

    如果一個代碼項在聲明和定義之前都有詳細說明, 則doxygen使用定義之前的說明。
    
用QT風格注釋的C++代碼樣例

 

//!  A test class.
/*!
  A more elaborate class description.
*/

 

class Test
{

  public:

    //! An enum.
    /*! More detailed enum description. */
    enum TEnum {
        TVal1, /*!< Enum value TVal1. */
        TVal2, /*!< Enum value TVal2. */
        TVal3  /*!< Enum value TVal3. */
    }
    //! Enum pointer.
    /*! Details. */
    *enumPtr,//! Enum variable.
             /*! Details. */

    enumVar; //! A constructor.
            
    /*!
      A more elaborate description of the constructor.
    */
    Test();

 

    //! A destructor.
    /*!
      A more elaborate description of the destructor.
    */
   ~Test();

   

    //! A normal member taking two arguments and returning an integer value.
    /*!
      \param a an integer argument.
      \param s a constant character pointer.
      \return The test results
      \sa Test(), ~Test(), testMeToo() and publicVar()
    */

    int testMe(int a,const char *s);
      

    //! A pure virtual member.
    /*!
      \sa testMe()
      \param c1 the first argument.
      \param c2 the second argument.
    */

    virtual void testMeToo(char c1,char c2) = 0;
 

    //! A public variable.
    /*!
      Details.
    */

    int publicVar;

      

    //! A function variable.
    /*!
      Details.
    */

    int (*handler)(int a,int b);

};

 


如果配置文件中JAVADOC_AUTOBRIEF 設置成 YES,可以使用JavaDoc風格注釋
 

/**
 *  A test class. A more elaborate class description.
 */

 

class Test
{

  public:

 

    /**
     * An enum.
     * More detailed enum description.
     */

 

    enum TEnum {
          TVal1, /**< enum value TVal1. */
          TVal2, /**< enum value TVal2. */
          TVal3  /**< enum value TVal3. */
         }
       *enumPtr, /**< enum pointer. Details. */
       enumVar;  /**< enum variable. Details. */
      

      /**
       * A constructor.
       * A more elaborate description of the constructor.
       */

      Test();

 

      /**
       * A destructor.
       * A more elaborate description of the destructor.
       */

     ~Test();

   

      /**
       * a normal member taking two arguments and returning an integer value.
       * @param a an integer argument.
       * @param s a constant character pointer.
       * @see Test()
       * @see ~Test()
       * @see testMeToo()
       * @see publicVar()
       * @return The test results
       */

       int testMe(int a,const char *s);

      

      /**
       * A pure virtual member.
       * @see testMe()
       * @param c1 the first argument.
       * @param c2 the second argument.
       */
       virtual void testMeToo(char c1,char c2) = 0;


      /**
       * a public variable.
       * Details.
       */

       int publicVar;

      

      /**
       * a function variable.
       * Details.
       */

       int (*handler)(int a,int b);

};


From:http://www.embstudy.org/home/space.php?uid=8&do=blog&id=66

posted on 2009-07-25 17:46 expter 閱讀(762) 評論(1)  編輯 收藏 引用

評論

# re: 轉:doxygen 使用簡介(C,C++為代碼作注釋) 2009-07-25 18:21 黑色靈貓

本文不錯,最近剛弄好lua的,返回來看下c++的doxygen,免得再google了  回復  更多評論   


只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            午夜精品久久久久久久99水蜜桃| 欧美日韩欧美一区二区| 欧美日韩1234| 国产亚洲一区二区三区在线观看| 亚洲欧洲一区二区在线播放| 亚洲欧美日韩天堂一区二区| 免费观看30秒视频久久| 99这里有精品| 久久青草福利网站| 国产精品成av人在线视午夜片| 激情欧美一区二区| 亚洲欧美国产一区二区三区| 欧美成人69av| 午夜精品美女久久久久av福利| 猛干欧美女孩| 国产亚洲精品久久久久婷婷瑜伽| 99国产精品国产精品毛片| 久久精品一区二区三区不卡牛牛| 亚洲免费观看视频| 久久五月天婷婷| 国产麻豆91精品| 亚洲视频导航| 欧美激情视频免费观看| 午夜一区不卡| 国产精品videossex久久发布| 亚洲国产三级| 久久精品网址| 亚洲欧美国产毛片在线| 欧美日本在线视频| 亚洲国产精品电影| 久久久国产精品一区二区中文 | 欧美成人亚洲成人| 亚洲免费在线| 欧美三级网页| 亚洲另类自拍| 欧美电影免费| 久久久久.com| 国产日韩高清一区二区三区在线| 亚洲午夜久久久久久尤物| 亚洲国产另类久久久精品极度| 久久国产一区二区三区| 国产麻豆综合| 亚洲免费网址| 在线一区二区三区四区五区| 欧美日产一区二区三区在线观看| 亚洲国产精品黑人久久久| 久久综合亚洲社区| 欧美在线观看视频在线| 国产精品一区二区久久| 午夜视频久久久| 一区二区三区视频在线播放| 欧美精品v日韩精品v韩国精品v| 亚洲国产精品一区二区三区| 浪潮色综合久久天堂| 久久国产精品久久精品国产| 国产亚洲欧美日韩一区二区| 久久精品二区亚洲w码| 亚洲欧美中文日韩v在线观看| 国产精品区二区三区日本| 亚洲图片在线观看| 一区二区欧美亚洲| 国产精品黄页免费高清在线观看| 亚洲视频在线免费观看| 99成人在线| 国产精品国产三级国产| 亚洲视频在线一区| 99精品热视频只有精品10| 欧美日韩亚洲综合一区| 亚洲影音先锋| 亚洲欧美国产77777| 国产一二精品视频| 久久综合亚州| 欧美aa在线视频| 99精品视频一区二区三区| 99国产精品国产精品久久| 国产精品二区二区三区| 午夜天堂精品久久久久| 性欧美暴力猛交另类hd| 精品成人久久| 亚洲高清免费在线| 欧美日韩精品免费| 亚洲欧美日韩综合国产aⅴ| 午夜精品视频在线| 在线播放日韩| 亚洲日韩欧美视频| 国产精品家庭影院| 久久久久久久久蜜桃| 久久综合99re88久久爱| 亚洲美女中出| 中文av一区二区| 国产午夜精品久久久| 欧美ed2k| 欧美日韩调教| 久久精品女人天堂| 免费成人av在线看| 亚洲午夜未删减在线观看| 欧美亚洲三级| 亚洲精品偷拍| 亚洲在线视频网站| 亚洲第一主播视频| 99精品视频一区| 国产一区二区三区免费在线观看| 美女国产精品| 欧美日韩在线播放三区四区| 欧美在线首页| 欧美高清一区| 久久国产精品久久w女人spa| 免费成人小视频| 性欧美精品高清| 快射av在线播放一区| 亚洲伊人伊色伊影伊综合网| 久久精品国产亚洲a| 一本到12不卡视频在线dvd| 亚洲欧美一区二区三区极速播放| 亚洲国产高清高潮精品美女| 一区二区三区免费在线观看| 在线观看日产精品| 中文精品99久久国产香蕉| 在线看无码的免费网站| 一本色道久久综合精品竹菊| 激情成人av| 亚洲视频中文字幕| 亚洲激情视频网| 亚洲欧美日韩国产综合在线| 亚洲精品美女在线观看播放| 亚洲欧美日韩一区二区三区在线| 亚洲破处大片| 欧美在线网站| 亚洲天堂av图片| 男人的天堂亚洲| 久久精品九九| 国产精品久久久久久久午夜片 | 在线视频一区二区| 久久露脸国产精品| 欧美一区视频在线| 欧美日韩麻豆| 欧美国产一区视频在线观看 | 久久综合色天天久久综合图片| 亚洲欧美日韩国产| 欧美精品综合| 欧美电影在线观看完整版| 国产午夜精品理论片a级探花| 亚洲九九精品| 亚洲精品国精品久久99热一| 久久久久久一区二区三区| 欧美亚洲一区二区在线观看| 欧美日韩一区二区在线| 亚洲盗摄视频| 在线观看亚洲a| 久久成人精品| 久久精品成人| 国产精品一区久久久| 一区二区福利| 亚洲午夜视频在线观看| 欧美美女喷水视频| 亚洲黑丝在线| 亚洲黄色在线视频| 久久亚洲欧洲| 欧美mv日韩mv国产网站app| 狠狠色伊人亚洲综合成人| 性久久久久久| 久久国产精品网站| 国产日产高清欧美一区二区三区| 亚洲视频专区在线| 亚洲在线黄色| 国产精品久久毛片a| 亚洲一本视频| 性色一区二区三区| 国产欧美日本| 欧美一区二区三区在线看| 久久福利精品| 好吊妞**欧美| 久久久精品国产一区二区三区| 久久久一区二区| 一区二区三区亚洲| 久久人人精品| 欧美国产欧美亚洲国产日韩mv天天看完整 | 亚洲视频电影在线| 欧美三日本三级少妇三2023| 日韩一级在线| 亚洲欧美日韩在线播放| 国产精品自拍三区| 性欧美大战久久久久久久久| 久久精品国产亚洲aⅴ| 国产亚洲二区| 久久久久中文| 欧美激情1区2区3区| 亚洲精品一区二区三区蜜桃久| 欧美精品三区| 一本久久a久久免费精品不卡| 亚洲欧美日韩综合aⅴ视频| 国产欧美精品一区二区三区介绍| 欧美影片第一页| 欧美本精品男人aⅴ天堂| 亚洲精品色婷婷福利天堂| 欧美日韩精选| 亚洲欧美另类在线观看| 久久视频精品在线| 亚洲欧洲精品一区二区精品久久久| 欧美精品少妇一区二区三区|