• <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++ 基礎
            国产成人久久AV免费| 久久久久久国产精品无码下载| 中文国产成人精品久久亚洲精品AⅤ无码精品 | 伊人丁香狠狠色综合久久| 久久青青草原精品国产不卡| 亚洲国产成人精品久久久国产成人一区二区三区综 | 香港aa三级久久三级老师2021国产三级精品三级在 | 精品久久久无码中文字幕| 亚洲中文字幕无码久久精品1 | 99久久国产综合精品五月天喷水 | 久久夜色精品国产亚洲| 久久久久亚洲AV成人网人人网站 | 久久国产视频99电影| 久久99精品国产自在现线小黄鸭 | 久久91亚洲人成电影网站| 综合久久久久久中文字幕亚洲国产国产综合一区首 | 久久er99热精品一区二区| 精品99久久aaa一级毛片| 精品久久久久久中文字幕人妻最新| 久久久久国产一区二区| 国产成人香蕉久久久久| 99国产精品久久久久久久成人热| 亚洲欧洲久久久精品| 久久精品这里只有精99品| 久久免费线看线看| 狠色狠色狠狠色综合久久| 欧美熟妇另类久久久久久不卡| 人妻中文久久久久| 精品久久久久久无码人妻热| 久久国产高清字幕中文| 久久精品国产精品青草app| www.久久热.com| 99久久婷婷免费国产综合精品| 亚洲人成网亚洲欧洲无码久久 | 久久97久久97精品免视看| 成人精品一区二区久久| 久久国产精品免费一区| 精品国产婷婷久久久| 国产午夜精品久久久久九九电影| 伊人色综合久久| 久久国产影院|