• <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>

            勤能補拙,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 閱讀(750) 評論(1)  編輯 收藏 引用

            評論

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

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

            中文成人久久久久影院免费观看| 久久久中文字幕| 亚洲精品乱码久久久久久按摩| 日韩精品无码久久久久久| 99久久精品国产麻豆| 伊人丁香狠狠色综合久久| 香蕉久久夜色精品国产2020| 亚洲综合精品香蕉久久网| 亚洲午夜精品久久久久久人妖| 久久影视综合亚洲| 国产一级持黄大片99久久| 一本色道久久88综合日韩精品 | 久久九九亚洲精品| 久久午夜综合久久| 99久久精品国产麻豆| 久久热这里只有精品在线观看| 日本久久久久久中文字幕| 亚洲av成人无码久久精品| 久久精品亚洲乱码伦伦中文| 久久久久久人妻无码| 中文字幕无码av激情不卡久久| 日本精品久久久中文字幕| 久久久久99精品成人片直播| 中文字幕无码久久人妻| 国产69精品久久久久99| 91视频国产91久久久| 亚洲精品乱码久久久久久蜜桃图片| 久久综合给合综合久久| 狠狠久久综合| 久久久久婷婷| 久久99精品久久久久久秒播| 精品久久久久久国产91| av无码久久久久不卡免费网站| 性欧美大战久久久久久久久 | 久久久精品日本一区二区三区| 久久国产精品一区二区| 久久精品国产亚洲麻豆| 日本精品久久久久中文字幕| 大美女久久久久久j久久| 久久久久婷婷| 狠狠综合久久AV一区二区三区|