一个非常奇怪的C++拷贝构造函数问题
生活随笔
收集整理的這篇文章主要介紹了
一个非常奇怪的C++拷贝构造函数问题
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
編譯環境:VS2022,C++14,對比測試如下:
測試一:
#include <iostream>class CTestA { public:CTestA() {printf("CTestA-contruct\n");}CTestA(const CTestA& other) {printf("copy-construct");}CTestA& operator=(const CTestA& other) = delete; }; int main() {CTestA oa = CTestA();//輸出結果如下 //CTestA-contruct }通過該測試知道:CTestA oa = CTestA()這行代碼導致了構造函數被調用,但拷貝構造函數并沒有使用,operator=也沒有被調用。
測試二:
#include <iostream>class CTestA { public:CTestA() {printf("CTestA-contruct\n");}CTestA(const CTestA& other) = delete;CTestA& operator=(const CTestA& other) = delete; }; int main() {CTestA oa = CTestA();}該測試無法通過,編譯錯誤如下
? ? //1>E:\UETest\TestCPP\TestCPP.cpp(18,1): error C2280: “CTestA::CTestA(const CTestA &)”: 嘗試引用已刪除的函數。
這說明,編譯時會嘗試調用拷貝構造函數!
這就非常奇怪了,通過測試一我們知道拷貝構造函數不會被調用,而這里又證明它會被調用!
沒搞明白這是怎么回事,猜想可能是編譯時確實會調用拷貝構造函數,但運行時被優化掉了?
總結
以上是生活随笔為你收集整理的一个非常奇怪的C++拷贝构造函数问题的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: UE4 C++与蓝图的继承问题
- 下一篇: C++友元与输出运算符重载