
C++中为什么vector的读写速度比原生数组快
4个回答
2016-01-26 · 知道合伙人互联网行家

知道合伙人互联网行家
采纳数:5637
获赞数:17441
毕业于曲阜师范大学,学士学位。互联网行业2年从业经验,读过SEO相关书籍。现任爱家网SEO优化专员。
向TA提问 私信TA
关注

展开全部
因为vector的构造函数会把每个元素初始化一遍,所以后面的访问cache命中就比另外两个高。
你如果在stdarr的定义和start = now之间加一句fill(stdarr.begin(), stdarr.end(), 0)那么它就和vector速度一样了, 原生数组同理。
你如果在stdarr的定义和start = now之间加一句fill(stdarr.begin(), stdarr.end(), 0)那么它就和vector速度一样了, 原生数组同理。
展开全部
vector的本质就是数组
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
你怎么测试的?我怀疑是你测试代码的问题
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
我也不知道为什么会有这么一个结论
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询