青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

posts - 28, comments - 179, trackbacks - 0, articles - 1
  C++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理

MSVC8中的SafeCode對性能的影響

Posted on 2007-06-11 10:51 chemz 閱讀(2122) 評論(4)  編輯 收藏 引用 所屬分類: C++
                          MSVC8中的SafeCode對性能的影響
    由于前面一篇關(guān)于編譯boost1.34.0編譯的blog
http://www.shnenglu.com/chemz/archive/2007/06/06/25666.html
中有人提到在Visual C++ 2005中由于微軟采用了safe code技術(shù)會對性能產(chǎn)生非常大的影
響(下降50%),所以本著性能不可以通過估計(jì)和猜測來確定,所以編寫了一個(gè)針對于此的
測試程序進(jìn)行了測試。
    該測試程序?yàn)榱俗龅阶銐虻母采wC++標(biāo)準(zhǔn)庫中STL部分,所以選擇了容器/跌代器/算法三
個(gè)關(guān)鍵組成中的具有代表性的類和對象進(jìn)行了測試。首先解釋一下微軟所提供的safe code
的目的和作用,由于STL庫中為了考慮到性能的最大化所以對于像:邊界值檢查、合法性檢
查以及范圍檢查等都省略了,此部分需要依靠程序員自行處理,而safe code就是在STL設(shè)計(jì)
到此部分的代碼中添加了判斷用的語句(通過宏引入的)。究竟會不會影響到性能呢?有多
大的影響呢?
    測試代碼如下:
        #include <iostream>
        #include <ctime>
        #include <vector>
        #include <list>
        #include <map>
        #include <algorithm>
        
        #include <boost/lambda/lambda.hpp>
        #include <boost/lambda/bind.hpp>
       
        #define MAX_TEST_COUNT 1000 * 1000 * 2
        #define TIME_ELAPSE() ( std::clock() - start * 1.0 ) / CLOCKS_PER_SEC
       
        int main( int argc, char *argv[] )
        {
            double times[6];
            size_t idx = 0;
            /*
             * vector
             */
            std::vector<size_t> vec1;
            std::clock_t start = std::clock();
            {
                for ( size_t i = 0; i < MAX_TEST_COUNT; ++i )
                {
                    vec1.push_back( i );
                }
            }
            times[idx++] = TIME_ELAPSE();
       
            std::vector<std::string> vec2;
            start = std::clock();
            {
                for ( size_t i = 0; i < MAX_TEST_COUNT; ++i )
                {
                    vec2.push_back( "std::vector<std::string>" );
                }
            }
            times[idx++] = TIME_ELAPSE();
            /*
             * list
             */
            std::list<size_t> lst1;
            start = std::clock();
            {
                for ( size_t i = 0; i < MAX_TEST_COUNT; ++i )
                {
                    lst1.push_back( i );
                }
            }
            times[idx++] = TIME_ELAPSE();
       
            std::list<std::string> lst2;
            start = std::clock();
            {
                for ( size_t i = 0; i < MAX_TEST_COUNT; ++i )
                {
                    lst2.push_back( "std::vector<std::string>" );
                }
            }
            times[idx++] = TIME_ELAPSE();
            /*
             * map
             */
            std::map<size_t, size_t> map1;
            start = std::clock();
            {
                for ( size_t i = 0; i < MAX_TEST_COUNT; ++i )
                {
                    map1.insert( std::make_pair( i, i ) );
                }
            }
            times[idx++] = TIME_ELAPSE();
       
            std::map<size_t, std::string> map2;
            start = std::clock();
            {
                for ( size_t i = 0; i < MAX_TEST_COUNT; ++i )
                {
                    map2.insert( std::make_pair( i, "std::vector<std::string>" ) );
                }
            }
            times[idx++] = TIME_ELAPSE();
       
            std::cout << "std::vector<size_t>::push_back        " << times[0] << " s" << std::endl;
            std::cout << "std::vector<std::string>::push_back   " << times[1] << " s" << std::endl;
            std::cout << "std::list<size_t>::push_back          " << times[2] << " s" << std::endl;
            std::cout << "std::list<std::string>::push_back     " << times[3] << " s" << std::endl;
            std::cout << "std::map<size_t, size_t>::insert      " << times[4] << " s" << std::endl;
            std::cout << "std::map<size_t, std::string>::insert " << times[5] << " s" << std::endl;
       
            std::cout << std::endl;
            /*
             * iterator
             */
            idx = 0;
            start = std::clock();
            {
                for ( std::vector<size_t>::iterator it = vec1.begin(); it != vec1.end(); ++it )
                {
                    (*it) = (*it) + 1;
                }
            }
            times[idx++] = TIME_ELAPSE();
            start = std::clock();
            {
                for ( std::vector<std::string>::iterator it = vec2.begin(); it != vec2.end(); ++it )
                {
                    (*it) = "std::vector<std::string>::iterator";
                }
            }
            times[idx++] = TIME_ELAPSE();
            start = std::clock();
            {
                for ( std::list<size_t>::iterator it = lst1.begin(); it != lst1.end(); ++it )
                {
                    (*it) = (*it) + 1;
                }
            }
            times[idx++] = TIME_ELAPSE();
            start = std::clock();
            {
                for ( std::list<std::string>::iterator it = lst2.begin(); it != lst2.end(); ++it )
                {
                    (*it) = "std::list<std::string>::iterator";
                }
            }
            times[idx++] = TIME_ELAPSE();
            start = std::clock();
            {
                for ( std::map<size_t, size_t>::iterator it = map1.begin(); it != map1.end(); ++it )
                {
                    (*it).second = (*it).second + 1;
                }
            }
            times[idx++] = TIME_ELAPSE();
            start = std::clock();
            {
                for ( std::map<size_t, std::string>::iterator it = map2.begin(); it != map2.end(); ++it )
                {
                    (*it).second = "std::map<size_t, std::string>::iterator";
                }
            }
            times[idx++] = TIME_ELAPSE();
       
            std::cout << "std::vector<size_t>::iterator           " << times[0] << " s" << std::endl;
            std::cout << "std::vector<std::string>::iterator      " << times[1] << " s" << std::endl;
            std::cout << "std::list<size_t>::iterator             " << times[2] << " s" << std::endl;
            std::cout << "std::list<std::string>::iterator        " << times[3] << " s" << std::endl;
            std::cout << "std::map<size_t, size_t>::iterator      " << times[4] << " s" << std::endl;
            std::cout << "std::map<size_t, std::string>::iterator " << times[5] << " s" << std::endl;
       
            std::cout << std::endl;
            /*
             * for_each
             */
            using namespace boost::lambda;
            idx = 0;
       
            start = std::clock();
            {
                std::for_each( vec1.begin(), vec1.end(), _1 = _1 + 1 );
            }
            times[idx++] = TIME_ELAPSE();
            start = std::clock();
            {
                std::for_each( vec2.begin(), vec2.end(), _1 = "std::for_each" );
            }
            times[idx++] = TIME_ELAPSE();
            start = std::clock();
            {
                std::for_each( lst1.begin(), lst1.end(), _1 = _1 + 1 );
            }
            times[idx++] = TIME_ELAPSE();
            start = std::clock();
            {
                std::for_each( lst2.begin(), lst2.end(), _1 = "std::for_each" );
            }
            times[idx++] = TIME_ELAPSE();
            start = std::clock();
            {
                std::for_each( map1.begin(), map1.end(), bind( &std::map<size_t, size_t>::value_type::second, _1 ) = bind( &std::map<size_t, size_t>::value_type::second, _1 ) + 1 );
            }
            times[idx++] = TIME_ELAPSE();
            start = std::clock();
            {
                std::for_each( map2.begin(), map2.end(), bind( &std::map<size_t, std::string>::value_type::second, _1 ) = "std::for_each" );
            }
            times[idx++] = TIME_ELAPSE();
       
            std::cout << "std::vector<size_t>::for_each           " << times[0] << " s" << std::endl;
            std::cout << "std::vector<std::string>::for_each      " << times[1] << " s" << std::endl;
            std::cout << "std::list<size_t>::for_each             " << times[2] << " s" << std::endl;
            std::cout << "std::list<std::string>::for_each        " << times[3] << " s" << std::endl;
            std::cout << "std::map<size_t, size_t>::for_each      " << times[4] << " s" << std::endl;
            std::cout << "std::map<size_t, std::string>::for_each " << times[5] << " s" << std::endl;
       
            return 0;
        }
    我的測試環(huán)境如下:
        軟件環(huán)境:Visual Studio2005 Pro + SP1, boost1.34.0
        硬件環(huán)境:PentiumD 3.0GHz, 4G RAM
    測試數(shù)據(jù):
        1. 默認(rèn)開啟safe code
           std::vector<size_t>::push_back        0.031 s
           std::vector<std::string>::push_back   2.609 s
           std::list<size_t>::push_back          0.797 s
           std::list<std::string>::push_back     2.813 s
           std::map<size_t, size_t>::insert      1.906 s
           std::map<size_t, std::string>::insert 4.047 s

           std::vector<size_t>::iterator           0 s
           std::vector<std::string>::iterator      1.718 s
           std::list<size_t>::iterator             0.016 s
           std::list<std::string>::iterator        1.734 s
           std::map<size_t, size_t>::iterator      0.063 s
           std::map<size_t, std::string>::iterator 1.891 s

           std::vector<size_t>::for_each           0.015 s
           std::vector<std::string>::for_each      0.156 s
           std::list<size_t>::for_each             0.016 s
           std::list<std::string>::for_each        0.156 s
           std::map<size_t, size_t>::for_each      0.078 s
           std::map<size_t, std::string>::for_each 0.313 s

        2. 關(guān)閉safe code(通過定義如下宏:_CRT_SECURE_NO_DEPRECATE,
                                          _SCL_SECURE_NO_DEPRECATE,
                                          _SECURE_SCL=0)
           std::vector<size_t>::push_back        0.031 s
           std::vector<std::string>::push_back   2.594 s
           std::list<size_t>::push_back          0.796 s
           std::list<std::string>::push_back     2.813 s
           std::map<size_t, size_t>::insert      1.875 s
           std::map<size_t, std::string>::insert 4.047 s

           std::vector<size_t>::iterator           0 s
           std::vector<std::string>::iterator      1.703 s
           std::list<size_t>::iterator             0.031 s
           std::list<std::string>::iterator        1.719 s
           std::map<size_t, size_t>::iterator      0.062 s
           std::map<size_t, std::string>::iterator 1.891 s

           std::vector<size_t>::for_each           0.016 s
           std::vector<std::string>::for_each      0.14 s
           std::list<size_t>::for_each             0.016 s
           std::list<std::string>::for_each        0.172 s
           std::map<size_t, size_t>::for_each      0.062 s
           std::map<size_t, std::string>::for_each 0.313 s

    由上面的測試數(shù)據(jù)可以的出如下的結(jié)論:
    1. safe code對代碼的性能確實(shí)是有影響的,畢竟加入了判斷的代碼;
    2. safe code對代碼的性能影響非常的小(最大沒有超過5%),基本上為了安全型可以
       忽略其影響,如果確實(shí)比較注重性能,可以考慮在release版本下關(guān)閉safe code檢查,
       在debug版下還是打開以發(fā)現(xiàn)錯(cuò)誤比較好。
 
注:宏解釋
    _CRT_SECURE_NO_DEPRECATE和_SCL_SECURE_NO_DEPRECATE用于關(guān)閉safe code代碼警告;
    _SECURE_SCL用于控制是否采用safe code對STL邊界進(jìn)行檢查。

Feedback

# re: MSVC8中的SafeCode對性能的影響  回復(fù)  更多評論   

2007-06-11 12:50 by pass86
。NET 2003,應(yīng)該就沒有。

# re: MSVC8中的SafeCode對性能的影響  回復(fù)  更多評論   

2007-06-11 13:18 by chemz
是的,safe code是在Visual C++2005以上版本添加上去的。visual C++.NET2003中的STL庫已經(jīng)非常的不錯(cuò)了,標(biāo)準(zhǔn)兼容性也很好。我最開始使用2003的時(shí)候使用了STLport4.6.2替換了2003中的STL實(shí)現(xiàn),感覺還不錯(cuò)的

# re: MSVC8中的SafeCode對性能的影響  回復(fù)  更多評論   

2007-06-11 14:47 by 空明流轉(zhuǎn)
50%的性能差異是在隨即容器隨機(jī)讀寫下完成的測試。某牛說。

# re: MSVC8中的SafeCode對性能的影響  回復(fù)  更多評論   

2007-10-11 10:06 by 金慶
push_back()是不需要邊界檢查的,所以性能測試無效:
vec1.push_back( i );
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            国产亚洲va综合人人澡精品| 欧美国产日韩一区二区| 欧美性大战久久久久| 日韩亚洲视频| 午夜精品在线| 亚洲盗摄视频| 欧美日韩国产一中文字不卡| 亚洲午夜激情免费视频| 久久精品盗摄| 最近看过的日韩成人| 欧美日本不卡高清| 亚洲综合电影| 欧美成年人网| 亚洲中午字幕| 亚洲国产成人精品久久久国产成人一区 | 国产情侣久久| 欧美在线视频在线播放完整版免费观看| 亚洲欧美变态国产另类| 国产在线不卡精品| 欧美精品午夜| 欧美在线观看一二区| 91久久国产综合久久91精品网站| 一区二区欧美亚洲| 国语精品一区| 欧美日韩精品中文字幕| 亚洲欧美日韩综合aⅴ视频| 欧美大片国产精品| 亚洲欧美视频在线观看| 尤物在线精品| 国产精品亚洲一区| 欧美xart系列高清| 欧美一区二区三区精品| 亚洲精品日本| 毛片基地黄久久久久久天堂| 亚洲欧美一级二级三级| 亚洲国产91色在线| 国产一区二区三区免费在线观看| 欧美成人资源网| 欧美一级视频免费在线观看| 亚洲精品视频在线观看网站| 久久在线免费观看| 亚洲欧美另类国产| 亚洲精品一区中文| 在线色欧美三级视频| 国产麻豆成人精品| 国产精品成人观看视频国产奇米| 女女同性女同一区二区三区91| 欧美一区91| 亚洲尤物影院| 一本不卡影院| 91久久亚洲| 欧美激情va永久在线播放| 欧美在线视频一区二区| 亚洲性夜色噜噜噜7777| 亚洲精品中文字幕有码专区| 韩日精品在线| 国产精品一区视频网站| 欧美性大战久久久久| 欧美日韩免费一区二区三区| 欧美黄色日本| 欧美电影在线观看完整版| 久久人人爽人人爽| 久久精品2019中文字幕| 欧美伊人久久大香线蕉综合69| 亚洲一二三区视频在线观看| 91久久国产自产拍夜夜嗨| 亚洲国产激情| 亚洲国产精品尤物yw在线观看| 欧美aa国产视频| 卡通动漫国产精品| 农村妇女精品| 欧美成人免费全部| 亚洲大胆女人| 亚洲精品国产无天堂网2021| 91久久黄色| 夜夜嗨av一区二区三区中文字幕| 亚洲美女电影在线| 一本久久a久久免费精品不卡| 99国产成+人+综合+亚洲欧美| 99在线热播精品免费99热| 亚洲伦理一区| 亚洲视频 欧洲视频| 亚洲女女做受ⅹxx高潮| 欧美一级一区| 久久精品视频免费| 欧美成人资源网| 欧美日韩中文字幕| 国产日韩欧美一二三区| 一区精品在线播放| 亚洲激情影视| 亚洲午夜在线视频| 久久久久久久综合狠狠综合| 噜噜噜噜噜久久久久久91 | 亚洲国产婷婷| 99国产精品视频免费观看| 亚洲愉拍自拍另类高清精品| 欧美在线黄色| 欧美福利视频| 国产精品亚洲激情| 亚洲成人在线免费| 亚洲视频自拍偷拍| 久久久精品国产99久久精品芒果| 牛人盗摄一区二区三区视频| 亚洲精品视频免费在线观看| 午夜欧美精品| 欧美国产日韩免费| 国产女主播在线一区二区| 91久久久亚洲精品| 香蕉国产精品偷在线观看不卡| 免费观看国产成人| 一区二区三区欧美激情| 久久久久久亚洲精品中文字幕| 欧美激情中文不卡| 国产亚洲欧美日韩日本| 亚洲精品日韩一| 久久精品成人一区二区三区蜜臀| 91久久精品日日躁夜夜躁国产| 亚洲一区二区三区在线视频| 免费看的黄色欧美网站| 国产精品试看| 亚洲精选中文字幕| 久久久久国产免费免费| 亚洲免费激情| 久久资源av| 国产视频丨精品|在线观看| 一本色道久久加勒比88综合| 久久视频精品在线| 一区二区三区日韩在线观看| 欧美成人午夜激情| 伊甸园精品99久久久久久| 亚洲永久免费精品| 亚洲人成网站在线播| 久久久久久久999精品视频| 国产精品嫩草久久久久| 99精品国产在热久久下载| 久久久久久高潮国产精品视| 亚洲视频一区二区在线观看 | 你懂的国产精品| 国产日韩亚洲欧美| 亚洲一区二区精品在线| 欧美激情久久久久| 久久九九国产精品| 国产日韩精品综合网站| 亚洲欧美日韩电影| 亚洲三级色网| 欧美激情一区二区三区在线视频| 在线精品在线| 久久漫画官网| 久久国产精品一区二区| 国产亚洲精品v| 欧美一级理论片| 亚洲专区在线视频| 国产精品www网站| 亚洲一区国产一区| 一区二区三区回区在观看免费视频| 欧美丰满高潮xxxx喷水动漫| 亚洲国产视频直播| 亚洲高清123| 欧美精品日韩一区| 99精品99| 99国产精品视频免费观看| 欧美日本国产精品| 在线综合亚洲欧美在线视频| 亚洲美女黄色| 欧美午夜不卡视频| 亚洲欧洲99久久| 亚洲综合色婷婷| 国产亚洲欧美一区二区三区| 久久精品女人天堂| 久久九九国产| 亚洲老板91色精品久久| 亚洲黄色尤物视频| 欧美日韩久久| 性亚洲最疯狂xxxx高清| 欧美一区二区三区四区在线| 国内精品免费在线观看| 久热成人在线视频| 女女同性女同一区二区三区91| 亚洲精品久久久久中文字幕欢迎你| 亚洲精品日韩综合观看成人91| 欧美日韩精品不卡| 性8sex亚洲区入口| 久久久国产91| 亚洲精品乱码久久久久久日本蜜臀 | 欧美国产丝袜视频| 日韩亚洲综合在线| 宅男在线国产精品| 国产在线视频不卡二| 米奇777超碰欧美日韩亚洲| 蜜桃av一区| 亚洲男同1069视频| 久久久精品网| 日韩视频一区二区在线观看 | 99re热精品| 国产伦精品一区二区三区在线观看 | 久久裸体视频| aaa亚洲精品一二三区| 亚洲视频精选在线| 亚洲第一天堂av| 亚洲黄色片网站|