深度探索C++ 对象模型(4)-Default Copy Constructor(4)
生活随笔
收集整理的這篇文章主要介紹了
深度探索C++ 对象模型(4)-Default Copy Constructor(4)
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
編譯器層NRV優化(Named Return Value)
原代碼為:
class testObj{friend testObj foo(double);public:testObj(){memset(array, 0, 10000 * sizeof(double));}public:double array[10000];inline testObj(const testObj &t)//優化代碼{memcpy(this, &t, sizeof(testObj));}};testObj foo(double val){testObj local;local.array[0] = val;local.array[99] = val;return local;} void test(){time_t timeVal;time(&timeVal);struct tm tVal;localtime_s(&tVal, &timeVal);cout << tVal.tm_hour << ":" << tVal.tm_min << ":" << tVal.tm_sec << endl; //start timefor (int i = 0; i < 10000000; i++){testObj t = foo(double(i));} time_t timeNow;time(&timeNow); struct tm tValNow;localtime_s(&tValNow, &timeNow);cout << tValNow.tm_hour << ":" << tValNow.tm_min << ":" << tValNow.tm_sec << endl; //end time }Visual Studio 2017 編譯結果 Debug模式
.禁用優化(點開項目“屬性頁”,配置屬性/“C/C++”/優化 )
輸出結果為55s
11:19:40
11:20:35
.打開優化
(“優化"改為“最大優化/O1”,與"優化"同級,點擊"代碼生成” ,"基本運行時檢查"改為“默認值”,若是RTC1則與之前得優化沖突)
輸出結果為18s
13:23:10
13:23:28
【引用】
[1]<<深度探索C++ 對象模型 Inside The C++ Object Model >> Stanley B.Lippman 候捷 譯
[2] 代碼地址 https://github.com/thefistlei/cplusStudy.git
總結
以上是生活随笔為你收集整理的深度探索C++ 对象模型(4)-Default Copy Constructor(4)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 深度探索C++ 对象模型(4)-Defa
- 下一篇: 深度探索C++ 对象模型(5)-Init