• <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了  回復  更多評論   

            欧美熟妇另类久久久久久不卡 | 亚洲国产精品综合久久网络 | 久久国产精品免费| 久久久久久久综合综合狠狠| 青春久久| 91久久精品视频| 思思久久精品在热线热| 久久国产精品-久久精品| 亚洲AⅤ优女AV综合久久久| 99久久人妻无码精品系列蜜桃| 99久久精品九九亚洲精品| 国产69精品久久久久久人妻精品| 久久综合欧美成人| 日本五月天婷久久网站| 国内精品伊人久久久久网站| 久久国产精品成人片免费| 亚洲人AV永久一区二区三区久久| 99re这里只有精品热久久| 奇米影视7777久久精品人人爽| 国产精品VIDEOSSEX久久发布| 老男人久久青草av高清| 久久久99精品一区二区| 久久精品嫩草影院| 国产精品青草久久久久婷婷| 国内精品九九久久精品| 最新久久免费视频| 久久只有这精品99| 亚洲国产天堂久久综合| 久久久久97国产精华液好用吗| 国产精品久久久久影视不卡| 欧美一区二区三区久久综合| 久久成人国产精品免费软件| 波多野结衣久久一区二区| 久久久久亚洲AV成人网人人网站 | 粉嫩小泬无遮挡久久久久久| 伊人久久大香线蕉AV一区二区| 久久久久久久国产免费看| 久久精品免费网站网| 手机看片久久高清国产日韩 | 久久精品国产亚洲AV麻豆网站 | 品成人欧美大片久久国产欧美... 品成人欧美大片久久国产欧美 |