當前位置:
首頁 >
C++/CLI思辨录之代理构造函数
發(fā)布時間:2025/6/15
48
豆豆
生活随笔
收集整理的這篇文章主要介紹了
C++/CLI思辨录之代理构造函数
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
現(xiàn)在我們討論一下新的C++/CLI環(huán)境下的一個很酷的特性,稱作代理構(gòu)造函數(shù)。?
對一個類來說,有多個構(gòu)造函數(shù)是經(jīng)常的事;并且這多個構(gòu)造函數(shù)有一段共同的代碼也很經(jīng)常。一般地,在這種情況下,我們都是為該共同代碼段編寫一個獨立的函數(shù),然后放在每個構(gòu)造器中調(diào)用。如下例:
但是現(xiàn)在利用C++/CLI引入的新特性-代理構(gòu)造器,我們可以從一個稱為基類構(gòu)造器的構(gòu)造器中調(diào)用另一個構(gòu)造器。當你這樣做時,執(zhí)行控制轉(zhuǎn)入到第二個構(gòu)造器中,在其執(zhí)行完后再返回到第一個構(gòu)造器。下面代碼片斷中的類Foo2演示了這種方法:
然而,每個類都應該包含至少一個非代理構(gòu)造器,不過該構(gòu)造器仍然可以有調(diào)用一個或者多個基類構(gòu)造器的初始化操作。
對一個類來說,有多個構(gòu)造函數(shù)是經(jīng)常的事;并且這多個構(gòu)造函數(shù)有一段共同的代碼也很經(jīng)常。一般地,在這種情況下,我們都是為該共同代碼段編寫一個獨立的函數(shù),然后放在每個構(gòu)造器中調(diào)用。如下例:
| class Foo { private: int _mem; public: Foo() : _mem(0) { CommonConstructor(); } Foo(int mem) : _mem(mem) { CommonConstructor(); } Foo(const Foo& f) : _mem(f._mem) { CommonConstructor(); } // 我們所有的構(gòu)造器都需要的代碼段? void CommonConstructor() { printf("Constructing the object"); } }; |
但是現(xiàn)在利用C++/CLI引入的新特性-代理構(gòu)造器,我們可以從一個稱為基類構(gòu)造器的構(gòu)造器中調(diào)用另一個構(gòu)造器。當你這樣做時,執(zhí)行控制轉(zhuǎn)入到第二個構(gòu)造器中,在其執(zhí)行完后再返回到第一個構(gòu)造器。下面代碼片斷中的類Foo2演示了這種方法:
| class Foo2 { private: int _mem; public: // 該構(gòu)造器調(diào)用第二個稱為基類構(gòu)造器的構(gòu)造器 Foo2() : Foo2(0) { } // 下面這個構(gòu)造器包含由所有構(gòu)造器使用的公共代碼 Foo2(int mem) : _mem(mem) { printf("Constructing the object");? } Foo2(const Foo2& f) : Foo2(f._mem) {? } }; |
然而,每個類都應該包含至少一個非代理構(gòu)造器,不過該構(gòu)造器仍然可以有調(diào)用一個或者多個基類構(gòu)造器的初始化操作。
注意,早期情況下,如果你想試用一下代理構(gòu)造函數(shù),應該會出現(xiàn)一個編譯錯誤。請注意,這是由于資源問題缺乏導致的,在現(xiàn)在版本的C++/CLI中可以避免這一錯誤。
本文轉(zhuǎn)自朱先忠老師51CTO博客,原文鏈接:?http://blog.51cto.com/zhuxianzhong/59847,如需轉(zhuǎn)載請自行聯(lián)系原作者
總結(jié)
以上是生活随笔為你收集整理的C++/CLI思辨录之代理构造函数的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 我的vExpert之路-传递正能量!
- 下一篇: (十二)springmvc+mybati