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

               C++ 技術中心

               :: 首頁 :: 聯系 ::  :: 管理
              160 Posts :: 0 Stories :: 87 Comments :: 0 Trackbacks

            公告

            鄭重聲明:本BLOG所發表的原創文章,作者保留一切權利。必須經過作者本人同意后方可轉載,并注名作者(天空)和出處(CppBlog.com)。作者Email:coder@luckcoder.com

            留言簿(27)

            搜索

            •  

            最新隨筆

            最新評論

            評論排行榜

            9. 若不想使用編譯器自動生成的函數,就該明確的拒絕

            #include "stdafx.h"
            #include <string>

            using namespace  std;

            class UnCopyAble
            {
            protected:
                UnCopyAble(){}
                ~UnCopyAble(){}

            private:
                //放入private,則不允許使用拷貝構造和對象間賦值
                
            //即使不慎在 membre或friend中使用,則鏈接通不過。
                
            //原因是只有聲明
                UnCopyAble(const UnCopyAble&);
                UnCopyAble& operator=(const UnCopyAble &);
            };

            class HomeForSale : private UnCopyAble //class 不再聲明copy構造函數和賦值重載
            {
            public:

            };

            int _tmain(int argc, _TCHAR* argv[])
            {
                HomeForSale sale1;
                
                
                //以下將不允許
                HomeForSale sale2(sale1);

                //以下將不允許
                HomeForSale sale3;
                sale3 = sale1;
                return 0;
            }
            10.為多態基類聲明virtual析構函數
               
               總結:帶有多態性質的基類應該聲明一個virtual析構函數。如果class帶有任何virutal,它也應該擁有一個virtual析構函數。
            class設計目的不是作為基類來使用的,或不是為了具備多態性,就不應該聲明virutal析構函數(一個類如果加入了virutal函數,則類大小
            會發生變化。因為有包含virutal table pointer)。

            11. 別讓異常逃離析構函數
             
             析構函數絕對不要吐出異常,這樣會帶來“過早結束程序”或“發生不明確行為”。如果一個析構函數可能要拋出異常,析構函數應該捕捉任何異常,然后吞下
            它,或者結束程序。如果要在某個函數運行時拋出的異常做出反應,那么class應該提供一個普通函數執行這個操作。例如下:
            class DBConn
            {
            public:

                //供客戶使用的函數
                void Close()
                {
                    db.close();
                    closed = true;
                }

                ~DBConn()
                {
                    if(!closed)
                    {
                        try
                        {
                            db.close(); //關閉連接,如果客戶不調用Close的話
                        }
                        catch ()
                        {
                            //寫入日志,記下close調用失敗
                        }
                    }
                }

            private:
                DBConnection db;
                bool closed;
            12. 絕不在構造和析構過程中調用virtual函數
            // testss.cpp : 定義控制臺應用程序的入口點。
            //

            #include "stdafx.h"
            #include <string>
            #include <list>

            using namespace  std;


            class Transaction
            {
            public:
                Transaction();
                void init();
                virtual void logTranscation() = 0;

            };

            Transaction::Transaction()
            {
                init();
            }

            void Transaction::init()
            {
                logTranscation();
            }

            class BuyTransaction : public Transaction
            {
            public:
                void logTranscation()
                {
                    printf("BuyTransaction log\n");
                }
            };


            int _tmain(int argc, _TCHAR* argv[])
            {
                BuyTransaction b;
                return 0;
            }
            以上代碼,會有一個BuyTransaction構造函數被調用,但首先是Transaction更早被調用。在derived class對象的base class構造期間,對象的類型是base class.若使用運行期類型信息,也會把對象視為base class類型。本例,構造函數中調用init,而init中調用Transaction::logTransaction。而logTransaction又是抽象方法,導致程序異常中止。當然如果非抽象方法,則會調用Transaction中的logTransaction。

                同樣,析構函數,一旦derived class析構函數先開始執行。對象內的derived class成員變量便呈現現未定義值。所以c++視它們不存在。進入base class析構函數后對象就成為一個base class對象。

            13. 令operator=返回一個reference to *this
            14. 在operator=中處理“自我賦值”
               
            posted on 2014-11-14 14:00 C++技術中心 閱讀(1885) 評論(0)  編輯 收藏 引用 所屬分類: C++ 基礎
            国产99久久久国产精品~~牛| 99久久99久久久精品齐齐 | 中文字幕精品无码久久久久久3D日动漫| 久久精品成人免费网站| 久久中文字幕视频、最近更新| 亚洲国产另类久久久精品黑人 | 久久九九有精品国产23百花影院| 久久99热这里只有精品国产| 久久久久亚洲av综合波多野结衣 | 国产成人精品久久一区二区三区av| 亚洲午夜福利精品久久| 欧美精品一区二区精品久久| 亚洲欧美国产精品专区久久| 国产精品久久久久久福利69堂| 久久av免费天堂小草播放| 久久综合狠狠综合久久| 亚洲日本va午夜中文字幕久久| 久久久无码一区二区三区| 久久久久一级精品亚洲国产成人综合AV区 | 狠狠色丁香婷综合久久| 久久99精品久久久大学生| 国产成人无码精品久久久久免费 | 亚洲欧美国产精品专区久久| 精品国产91久久久久久久a| www.久久热.com| 996久久国产精品线观看| 狠狠色丁香久久婷婷综合| 亚洲精品无码久久久| 国内精品久久国产| 欧美色综合久久久久久| 久久久久免费视频| 久久久久九国产精品| 久久久久99精品成人片三人毛片| 久久777国产线看观看精品| 1000部精品久久久久久久久| 久久久一本精品99久久精品66| 欧美黑人又粗又大久久久| 一本久久a久久精品亚洲| 亚洲AV乱码久久精品蜜桃| 久久人人爽爽爽人久久久| 99久久免费国产特黄|