C++探索構(gòu)造函數(shù)私有化會產(chǎn)生什么結(jié)果
提問:假設(shè)只有一個(gè)構(gòu)造方法,如果將之私有化會有什么后果
- 對于當(dāng)前類,它是無法實(shí)例化的
- 對于它的子類,子類也是無法實(shí)例化的
構(gòu)造函數(shù)與是否能夠?qū)嵗嘘P(guān)
對于單個(gè)類
正常情況下
#include <iostream> using namespace std; class EventDispatcher { public: void test_printf(){ std::cout << "test_printf --\r\n"; } EventDispatcher() = default; }; int main(int argc,char *argv[]){ EventDispatcher noticeCenter1; EventDispatcher *noticeCenter2 = new EventDispatcher; noticeCenter1.test_printf(); noticeCenter2->test_printf(); }
構(gòu)造函數(shù)私有化
#include <iostream> using namespace std; class EventDispatcher { public: void test_printf(){ std::cout << "test_printf --\r\n"; } private: EventDispatcher() = default; }; int main(int argc,char *argv[]){ EventDispatcher noticeCenter1; EventDispatcher *noticeCenter2 = new EventDispatcher; noticeCenter1.test_printf(); noticeCenter2->test_printf(); }
編譯通不過,因?yàn)闊o論是在棧還是堆上,都無法調(diào)用構(gòu)造函數(shù)來生成對象
私有化與繼承
正常情況下
#include <iostream> using namespace std; class EventDispatcher { public: void test_printf(){ std::cout << "test_printf --\r\n"; } EventDispatcher() = default; }; class NoticeCenter : public EventDispatcher{ public: void test_Center(){ std::cout << "test_Center --\r\n"; } }; int main(int argc,char *argv[]){ NoticeCenter noticeCenter1; NoticeCenter *noticeCenter2 = new NoticeCenter; noticeCenter1.test_printf(); noticeCenter2->test_printf(); noticeCenter1.test_Center(); noticeCenter2->test_Center(); }
2. 父類構(gòu)造函數(shù)私有化,而且子類沒有提供public的構(gòu)造函數(shù)----》 子類的構(gòu)造函數(shù)也是私有化的
#include <iostream> using namespace std; class EventDispatcher { public: void test_printf(){ std::cout << "test_printf --\r\n"; } private: EventDispatcher() = default; }; class NoticeCenter : public EventDispatcher{ public: void test_Center(){ std::cout << "test_Center --\r\n"; } }; int main(int argc,char *argv[]){ NoticeCenter noticeCenter1; NoticeCenter *noticeCenter2 = new NoticeCenter; noticeCenter1.test_printf(); noticeCenter2->test_printf(); noticeCenter1.test_Center(); noticeCenter2->test_Center(); }
父類構(gòu)造函數(shù)私有化,而且子類提供public的構(gòu)造函數(shù)----》編譯還是不能通過
#include <iostream> using namespace std; class EventDispatcher { public: void test_printf(){ std::cout << "test_printf --\r\n"; } private: EventDispatcher() = default; }; class NoticeCenter : public EventDispatcher{ public: void test_Center(){ std::cout << "test_Center --\r\n"; } public: NoticeCenter() = default; //沒有作用 //此時(shí)子類無法提供除了默認(rèn)構(gòu)造函數(shù)之外的函數(shù),比如 NoticeCenter(int a) }; int main(int argc,char *argv[]){ NoticeCenter noticeCenter1; NoticeCenter *noticeCenter2 = new NoticeCenter; noticeCenter1.test_printf(); noticeCenter2->test_printf(); noticeCenter1.test_Center(); noticeCenter2->test_Center(); }
結(jié)論:只要繼承了一個(gè)無法實(shí)例化的父類,不管子類怎么折騰,都無法實(shí)例化。 這也是noncopyable類的由來
成員變量與私有化
正常情況下
#include <iostream> using namespace std; class EventDispatcher { public: void test_printf(){ std::cout << "test_printf --\r\n"; } EventDispatcher() = default; }; class NoticeCenter { public: void test_Center(){ a.test_printf(); std::cout << "test_Center --\r\n"; } EventDispatcher a; }; int main(int argc,char *argv[]){ NoticeCenter noticeCenter1; NoticeCenter *noticeCenter2 = new NoticeCenter; noticeCenter1.test_Center(); noticeCenter2->test_Center(); }
2. 如果當(dāng)前類的某個(gè)成員變量是無法實(shí)例化的,那么當(dāng)前類也無法實(shí)例化(正常,某個(gè)組件無法實(shí)例化,那么整個(gè)構(gòu)建就會出問題)
#include <iostream> using namespace std; class EventDispatcher { public: void test_printf(){ std::cout << "test_printf --\r\n"; } private: EventDispatcher() = default; }; class NoticeCenter { public: void test_Center(){ std::cout << "test_Center --\r\n"; a.test_printf(); } EventDispatcher a; }; int main(int argc,char *argv[]){ NoticeCenter noticeCenter1; NoticeCenter *noticeCenter2 = new NoticeCenter; noticeCenter1.test_Center(); noticeCenter2->test_Center(); }
解決方法:友元類可以訪問某個(gè)類的私有成員,所以將令構(gòu)件為某個(gè)組件的友元類,這樣構(gòu)件就可以去訪問組件私有的構(gòu)造函數(shù),將之構(gòu)造出來了
#include <iostream> using namespace std; class EventDispatcher { friend class NoticeCenter ; public: void test_printf(){ std::cout << "test_printf --\r\n"; } private: EventDispatcher() = default; }; class NoticeCenter { public: void test_Center(){ std::cout << "test_Center --\r\n"; a.test_printf(); } EventDispatcher a; }; int main(int argc,char *argv[]){ NoticeCenter noticeCenter1; NoticeCenter *noticeCenter2 = new NoticeCenter; noticeCenter1.test_Center(); noticeCenter2->test_Center(); }
到此這篇關(guān)于C語言探索構(gòu)造函數(shù)私有化會產(chǎn)生什么結(jié)果的文章就介紹到這了,更多相關(guān)C語言構(gòu)造函數(shù)私有化內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Qt音視頻開發(fā)之利用ffmpeg實(shí)現(xiàn)倍速播放
這篇文章主要為大家詳細(xì)介紹了在Qt音視頻開發(fā)中如何利用ffmpeg實(shí)現(xiàn)倍速播放功能(半倍速/2倍速/4倍速/8倍速),感興趣的小伙伴可以了解一下2022-11-11解析C/C++指針、函數(shù)、結(jié)構(gòu)體、共用體
這篇文章主要介紹了C/C++指針、函數(shù)、結(jié)構(gòu)體、共用體的相關(guān)知識,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-01-01OpenCV實(shí)現(xiàn)相機(jī)標(biāo)定板
這篇文章主要為大家詳細(xì)介紹了OpenCV實(shí)現(xiàn)相機(jī)標(biāo)定板,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-04-04