C_and_CPP 板


LINE

※ 引述《yoco315 (眠月)》之铭言: : ※ 引述《holymars ()》之铭言: : : 有个STL容器 : : std::list<T> my_list; : : 要在容器最後面新增一个元素的时侯,下面两种方法哪一种比较有效率呢.. : : 1. : : T temp; : : // 对temp的内容操作.. : : my_list.push_back(temp); : : 2. : : my_list.resize(my_list.size() + 1); : : T& temp = my_list.back(); : : // 对temp的内容操作.. : : 之前一直习惯的写法都是1. : : 但是2.的作法好像少呼叫一次copy constructor : : 有人对这两种作法的效率问题作过实际的测试吗 @ @? : 直觉 2 完全占不到便宜, : 因为 resize 的瞬间你就要呼叫一个预设建构子, : 不过还是看一下 VC++ 2008 Express 附的实作版本好了…… : void resize(size_type _Newsize) : { // determine new length, padding with _Ty() elements as needed : resize(_Newsize, _Ty()); : } : void resize(size_type _Newsize, _Ty _Val) : { // determine new length, padding with _Val elements as needed : if (size() < _Newsize) : _Insert_n(end(), _Newsize - size(), _Val); : else if (_Newsize < size()) : erase(begin() + _Newsize, end()); : } : 首先,resize 会呼叫一次预设建构子, : 然後,会一两次条件判断,第二次不可能发生,所以忽略。 : 接着会进行一次 insert_n,这里头有个回圈,贵松松, : 虽然我们知道只会插一个,但是回圈还是得跑,有回圈就要破坏 pipeline 了, : 看了原始码就知道所谓的 resize 最後该花的钱(建构子)还是得花, : 考虑最佳化以後也许一些多余的复制成本省掉可以打平, : 但是那个条件判断跟那个回圈你还是要开销…… : 结果蛮明显的……真的要花时间测吗 XD??? 刚刚把STL container在VC8的实作码看了一遍 发现不同容器的作法不太一样 以std::vector来说的话 push_back()和resize() 实作都是用_Insert_n 差别在push_back()第二个参数是传(size_type)1 vector的_Insert_n底层是fill(),最底层是用memset作的 其实没有呼叫过copy constructor std::list就像上面说的那样 resize()多了一个回圈去呼叫多次的_Insert push_back() 直接去呼叫_Insert _Insert的里面是_BuyNode,最底层是一个copy constructor 虽然reference上说resize()如果大於目前size() 空的位置会使用default constructor来建立物件 但VC8的实作其实是像上述那样XD 所以原本的问题变成是 1. T temp; temp.operate(); container.push_back(temp); 2. container.push_back(T()); T& temp = container.back(); temp.operate(); 从实作码来看这两者跑的code是一样的 差别在於default constructor和copy constructor被呼叫的时机不一样 1.是先呼叫default ctor->对物件作操作->呼叫copy ctor 2.是呼叫default ctor->呼叫copy ctor->对物件作操作 对std::vector这个用memset取代掉copy ctor的容器来说两者应该是没差的 对std::list这种实际呼叫了copy ctor的容器来说 除非最佳化能把2.的前两个步骤合并成一个 或者你自己定义了一个奇怪的ctor作有条件的copy 不然两者要跑的code还是一样多.. --



※ 发信站: 批踢踢实业坊(ptt.cc)
◆ From: 114.32.15.163







like.gif 您可能会有兴趣的文章
icon.png[问题/行为] 猫晚上进房间会不会有憋尿问题
icon.pngRe: [闲聊] 选了错误的女孩成为魔法少女 XDDDDDDDDDD
icon.png[正妹] 瑞典 一张
icon.png[心得] EMS高领长版毛衣.墨小楼MC1002
icon.png[分享] 丹龙隔热纸GE55+33+22
icon.png[问题] 清洗洗衣机
icon.png[寻物] 窗台下的空间
icon.png[闲聊] 双极の女神1 木魔爵
icon.png[售车] 新竹 1997 march 1297cc 白色 四门
icon.png[讨论] 能从照片感受到摄影者心情吗
icon.png[狂贺] 贺贺贺贺 贺!岛村卯月!总选举NO.1
icon.png[难过] 羡慕白皮肤的女生
icon.png阅读文章
icon.png[黑特]
icon.png[问题] SBK S1安装於安全帽位置
icon.png[分享] 旧woo100绝版开箱!!
icon.pngRe: [无言] 关於小包卫生纸
icon.png[开箱] E5-2683V3 RX480Strix 快睿C1 简单测试
icon.png[心得] 苍の海贼龙 地狱 执行者16PT
icon.png[售车] 1999年Virage iO 1.8EXi
icon.png[心得] 挑战33 LV10 狮子座pt solo
icon.png[闲聊] 手把手教你不被桶之新手主购教学
icon.png[分享] Civic Type R 量产版官方照无预警流出
icon.png[售车] Golf 4 2.0 银色 自排
icon.png[出售] Graco提篮汽座(有底座)2000元诚可议
icon.png[问题] 请问补牙材质掉了还能再补吗?(台中半年内
icon.png[问题] 44th 单曲 生写竟然都给重复的啊啊!
icon.png[心得] 华南红卡/icash 核卡
icon.png[问题] 拔牙矫正这样正常吗
icon.png[赠送] 老莫高业 初业 102年版
icon.png[情报] 三大行动支付 本季掀战火
icon.png[宝宝] 博客来Amos水蜡笔5/1特价五折
icon.pngRe: [心得] 新鲜人一些面试分享
icon.png[心得] 苍の海贼龙 地狱 麒麟25PT
icon.pngRe: [闲聊] (君の名は。雷慎入) 君名二创漫画翻译
icon.pngRe: [闲聊] OGN中场影片:失踪人口局 (英文字幕)
icon.png[问题] 台湾大哥大4G讯号差
icon.png[出售] [全国]全新千寻侘草LED灯, 水草

请输入看板名称,例如:BabyMother站内搜寻

TOP