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

            Note of Justin

            關于工作和讀書的筆記

              C++博客 :: 首頁 :: 聯系 :: 聚合  :: 管理
              47 Posts :: 0 Stories :: 45 Comments :: 0 Trackbacks

            留言簿(14)

            搜索

            •  

            積分與排名

            • 積分 - 52490
            • 排名 - 433

            最新評論

            閱讀排行榜

            評論排行榜

            [原創文章歡迎轉載,但請保留作者信息]
            Justin 于 2010-04-26


            看完以后覺得講的其實是如何用模板函數來讓拷貝構造函數和賦值運算符接受所有可能的輸入。

            首先對于內建類型的對象,他們作為函數參數時,參數的類型轉換是自動發生的。比如說派生類對象的指針,如果需要,會被轉換為其父類對象的指針。
            而對于智能指針,要完成類似的轉換需要編寫額外的代碼才能實現。
            如書中例子所示,如果類Base是類Derived的父類,對于下面的一個模板類:
            template?<typename?T>
            class?SmartPointer?{
            public:
            ???
            explicit?SmartPointer(T?*?pointer);
            //..
            }

            經管這兩個智能指針指向的對象是有繼承關系的,SmartPointer<Base>和SmartPointer<Derived>對于編譯器來說完全沒有聯系。
            于是,如果一個函數聲明了接受一個SmartPointer<Base>類型的參數,就無法給它傳進一個SmartPointer<Derived>類型的指針了。

            為了能夠讓智能指針對象也具備一般指針的隱式轉換能力,首先可以做的工作是改造智能指針的構造函數,讓對象生成的時候可以依照具體情況“變態”成實際需要的對象類型。好吧,那我們現在就開始做……
            打??!有兩個問題需要考慮:第一是我們怎么知道智能指針構造函數的輸入參數pointer是什么類型?又怎么知道真正需要的目標類型是什么?如果不知道我們怎么寫這個構造函數?第二是就算我們知道了輸入的類型和生成的類型,有多少種這樣的搭配是SmartPointer需要接受的?如果有100對不同的類型搭配,我們就要寫100種構造函數嗎?
            解決這些問題的辦法:用“模板化”的構造函數。(member function templates)
            template?<typename?T>
            class?SmartPointer?{
            public:
            ???template?
            <typename?U>
            ???SmartPointer(
            const?SmartPointer<U>&?input)?:?myPointer(?input.get()?)
            ???{
            //..
            ???}
            ???T
            *?get()?const?{?return?myPointer;?}
            ???
            //..
            private:
            ???T
            *?myPointer;
            };

            上面的方案個人感覺很繞,不過確實也解決了問題。
            大概分析一下:
            • 其中的構造函數是一個模板函數,接受參數為U類型的對象,構造出指向T的指針。
            • 但是很明顯我們不需要一個能夠接受任意類型再生成任意類型對象的構造函數。這樣會天下大亂的。于是就有了get()對myPointer的初始化:構造函數的輸入參數input所持有的指針是可以用get()來得到的,然后有這個“get”來的指針去初始化目標對象所持有的指針,到了這一步,就和一般指針的隱式轉換沒有差別了:
              • 如果可以轉換,智能指針SmartPointer<U>就順利轉換為SmartPointer<T>;
              • 如果不能轉換,構造函數就失敗。
            • 這里的構造函數沒有explicit修飾,因此類型的轉換是隱式的。如果真有這個必要,就加上explicit,這樣就需要顯式地聲明需要進行類型轉換。
            • 當一個類沒有定義自己的構造函數時(包括賦值構造函數和拷貝構造函數),編譯器會“幫你”創建默認的構造函數。編譯器不會理睬“模板化”的構造函數,如果一個類中只有“模板化”的構造函數,它還是會繼續生產默認的構造函數。因此,如果不想讓編譯器做多余的事,就有必要自己寫好非模板化的構造函數,以此讓編譯器“閉嘴”@#¥%
            posted on 2010-04-26 08:45 Justin.H 閱讀(1374) 評論(0)  編輯 收藏 引用 所屬分類: Effective C++ 炒冷飯
            久久99久久成人免费播放| 精品久久久中文字幕人妻| 久久精品国产影库免费看| 精品免费久久久久国产一区| 久久青青草原亚洲av无码| 国色天香久久久久久久小说| 久久美女人爽女人爽| 亚洲精品tv久久久久久久久久| 久久香综合精品久久伊人| 99久久精品无码一区二区毛片| 2021国产精品午夜久久| 秋霞久久国产精品电影院| 伊人久久大香线焦AV综合影院| 国产精品久久久久乳精品爆 | 精品无码人妻久久久久久| 国产A级毛片久久久精品毛片| 国产精品99久久久久久董美香 | 婷婷综合久久中文字幕| 2021国内精品久久久久久影院| 成人精品一区二区久久| 久久精品国产亚洲精品2020| 狠狠色婷婷久久一区二区| 久久一区二区免费播放| 狠狠色综合久久久久尤物| 久久久久久a亚洲欧洲aⅴ| 国产精品久久久久国产A级| 久久婷婷国产剧情内射白浆 | 亚洲成av人片不卡无码久久| 国产精品久久久久久久午夜片| 久久久久国产一级毛片高清版| 久久国产精品久久国产精品| 久久精品一本到99热免费| 人妻无码中文久久久久专区| 少妇精品久久久一区二区三区| 国产成人精品久久| 亚洲级αV无码毛片久久精品| 一本色道久久HEZYO无码| 亚洲精品国精品久久99热一| 久久久无码人妻精品无码| 99久久婷婷国产综合亚洲| 国产成人99久久亚洲综合精品|