C++探索構造函數私有化會產生什麼結果
提問:假設隻有一個構造方法,如果將之私有化會有什麼後果
- 對於當前類,它是無法實例化的
- 對於它的子類,子類也是無法實例化的
構造函數與是否能夠實例化有關
對於單個類
正常情況下
#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(); }
構造函數私有化
#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(); }
編譯通不過,因為無論是在棧還是堆上,都無法調用構造函數來生成對象
私有化與繼承
正常情況下
#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. 父類構造函數私有化,而且子類沒有提供public的構造函數—-》 子類的構造函數也是私有化的
#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(); }
父類構造函數私有化,而且子類提供public的構造函數—-》編譯還是不能通過
#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; //沒有作用 //此時子類無法提供除瞭默認構造函數之外的函數,比如 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(); }
結論:隻要繼承瞭一個無法實例化的父類,不管子類怎麼折騰,都無法實例化。 這也是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. 如果當前類的某個成員變量是無法實例化的,那麼當前類也無法實例化(正常,某個組件無法實例化,那麼整個構建就會出問題)
#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(); }
解決方法:友元類可以訪問某個類的私有成員,所以將令構件為某個組件的友元類,這樣構件就可以去訪問組件私有的構造函數,將之構造出來瞭
#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(); }
到此這篇關於C語言探索構造函數私有化會產生什麼結果的文章就介紹到這瞭,更多相關C語言構造函數私有化內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!