卓航论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 254|回复: 3
打印 上一主题 下一主题

C/C++字符串处理之std::vector与std::StringBuilder

[复制链接]
[至尊红钻5级]发帖数量≥8000篇 [未点亮至尊黄钻]威望不足10点 [未点亮至尊蓝钻]在线时间不足10小时 [未点亮至尊绿钻]贡献度不足10点 [至尊紫钻4级]金币≥20000个 [未点亮至尊粉钻]精华贴数不足10贴 [未点亮至尊黑钻]活跃不足8个
 等级: 
 级别: 论坛元老
 UID:  7   [未点亮普号显示]钻石不足3个
 阁 分: 36567
 阁 望: 0
 阁 献: 0
 活 跃: 0
 发 贴: 12405 (0)
 阁 币: 24162  
性 别: I'm 火星人!
阅读权限: 90
在线时长: 0 小时
注册时间: 2016-10-16
最后登录: 2016-10-18
go
楼主
发表于 2016-10-17 16:23:11 |只看该作者 |倒序浏览
本帖发表于 2016-10-17 16:23:11...阅读 255 人...加油,亲爱的楼主:[db:作者]
引子
std::StringBuilder 基于 std::vector 实现。所以尽管本文讨论 std::vector,但是所有的结论对 std::StringBuilder 同样有效。
实现概要
简单来讲,std::vector 是一个动态数组,管理的是一块线性的、可 动态增长的内存。
如何加速 std::vector?
使用 vector::reserve
在大致可预估 vector 大小时,在插 入数据前,应该先调用 reserve(size) 进行内存的预分配(这里 size 是预估的vector元素个数)。
避免在vector开始 (begin)插入/删除数据
也就是说,应该尽量用 vector::insert(end(), …) 或者 vector::push_back/pop_back 添加/删除数据。而不要用 vector::insert(begin(), …) 操作。vector 没有提供 push_front 操作,原因只有一个: 从 vector 开始处插入/删除数据是低效的做法。
如果你需要大量的在容器开始(begin)处 insert 数据,那么可以选择 std::deque(有 vector 随机访问的优点,也有 list 高效插入的优点)或者 std::list。
std::vector 的缺陷
什么时候不能用 std::vector ?
在容器需要容纳海量数据,并且元素个数不可预知时,坚决不能用 std::vector。所有 基于线性内存的数据结构(如 std::vector,std::string)在海量数据时,遭遇性能瓶颈。
内存碎片
基于线性 内存的数据结构(如 std::vector,std::string),还有一个典型的问题,就是容易产生内存碎片。在大量操作 std::vector 或 std::string 后,内存碎片就会比较严重。
std::vector 与 allocator
我们知道,std::vector 的原型 是:
template  >
class vector;
那么是否需要像我们针对 Map/MultiMap、Set/MultiSet、List/Slist、HashMap/HashMultiMap 、HashSet/HashMultiSet、Deque 做的那样,将 AllocT 改用 GC Allocator呢?
答案是:不需要。GC Allocator 对于 改善小内存分配是有益的。但是在动态的线性内存的数据结构无效。这样的数据结构除了 std::vector 外,典型的还有 std::string(std::basic_string)。
推荐阅读
std::deque(http://cpp.winxgui.com/cn:std-deque) - 介于 std::vector 与 std::list 之间的一个数据结构,既可以随 机定位,海量数据是性能仍然非常稳健(事实上其 push_back/push_front 的性能几乎为常数:O(1),而不像 std::vector 那 样,随着元素的增加,插入速度急剧下降)。
std::list(http://cpp.winxgui.com/cn:std-list) - 双向链表。
分享到: QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏0 支持支持0 反对反对0

使用道具 举报

[至尊红钻3级]发帖数量≥1000篇 [未点亮至尊黄钻]威望不足10点 [未点亮至尊蓝钻]在线时间不足10小时 [未点亮至尊绿钻]贡献度不足10点 [未点亮至尊紫钻]金币不足100个 [未点亮至尊粉钻]精华贴数不足10贴 [未点亮至尊黑钻]活跃不足8个
 等级: 
 级别: 金牌会员
 UID:  2   [未点亮普号显示]钻石不足3个
 阁 分: 1290
 阁 望: 0
 阁 献: 0
 活 跃: 0
 发 贴: 1285 (0)
 阁 币: 5  
性 别: I'm 火星人!
阅读权限: 70
在线时长: 0 小时
注册时间: 2016-10-14
最后登录: 2016-10-18
沙发
发表于 2016-10-18 00:05:18 |只看该作者
本回复帖发表于 2016-10-18 00:05:18,感谢hjghjgj对本帖的认真回复,你的回复是对楼主莫大的鼓舞
看帖回帖是美德!

使用道具 举报

[至尊红钻2级]发帖数量≥100篇 [未点亮至尊黄钻]威望不足10点 [未点亮至尊蓝钻]在线时间不足10小时 [未点亮至尊绿钻]贡献度不足10点 [未点亮至尊紫钻]金币不足100个 [未点亮至尊粉钻]精华贴数不足10贴 [未点亮至尊黑钻]活跃不足8个
 等级: 
 级别: 注册会员
 UID:  67   [未点亮普号显示]钻石不足3个
 阁 分: 158
 阁 望: 2
 阁 献: 9
 活 跃: 0
 发 贴: 140 (0)
 阁 币: 5  
性 别: I'm 火星人!
阅读权限: 20
在线时长: 5 小时
注册时间: 2011-1-6
最后登录: 2016-10-21
板凳
发表于 2016-10-19 13:40:14 |只看该作者
本回复帖发表于 2016-10-19 13:40:14,感谢luckyboy123对本帖的认真回复,你的回复是对楼主莫大的鼓舞
好好 学习了 确实不错

使用道具 举报

[至尊红钻2级]发帖数量≥100篇 [未点亮至尊黄钻]威望不足10点 [未点亮至尊蓝钻]在线时间不足10小时 [未点亮至尊绿钻]贡献度不足10点 [未点亮至尊紫钻]金币不足100个 [未点亮至尊粉钻]精华贴数不足10贴 [未点亮至尊黑钻]活跃不足8个
 等级: 
 级别: 中级会员
 UID:  51   [未点亮普号显示]钻石不足3个
 阁 分: 205
 阁 望: 5
 阁 献: 3
 活 跃: 0
 发 贴: 182 (0)
 阁 币: 10  
性 别: I'm 火星人!
阅读权限: 30
在线时长: 5 小时
注册时间: 2011-1-6
最后登录: 2016-10-21
地板
发表于 2016-10-21 08:46:08 |只看该作者
本回复帖发表于 2016-10-21 08:46:08,感谢wangxuejing1109对本帖的认真回复,你的回复是对楼主莫大的鼓舞
路过,支持一下啦

使用道具 举报

高级模式
B Color Image Link Quote Code Smilies
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

1、请认真发帖,禁止回复纯表情,纯数字等无意义的内容!帖子内容不要太简单!
2、提倡文明上网,净化网络环境!抵制低俗不良违法有害信息。
3、每个贴内连续回复请勿多余3贴,每个版面回复请勿多余10贴!
4、如果你对主帖作者的帖子不屑一顾的话,请勿回帖。谢谢合作!

手机版| 百度搜索:vkee.pw

2012-2015 卓航旗下 GMT+8, 2024-6-16 19:42 , Processed in 0.608044 second(s), 30 queries . Powered by Discuz! X3.2  

禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.如遇版权问题,请及时联系站长(QQ:5213513)

今天是: | 本站已经安全运行: //这个地方可以改颜色

快速回复 返回顶部 返回列表