我是靠谱客的博主 贪玩星星,这篇文章主要介绍C++ 不使用vector的原因和替代方法,现在分享给大家,希望可以做个参考。

为什么80%的码农都做不了架构师?>>>   hot3.png

        vector<bool>的名称有点让人误解,因为其内部元素实际上并不是标准的bool值,C++标准对于vector<bool>值有其特殊的实现方法,目的是为了减小空间的耗用。特殊版本内部只使用一个bit来存储一个元素,所以通常要比一般的bool值小8倍之多。但是这里就带来了一个小麻烦,C++的最小可寻址值通常以byte为单位,所以上述的vector<bool>特殊版本的references和iterators经过了特殊的处理,并不是bool值的实际地址,而是一个“代理对象”。这样,对于一般类可以使用的以下操作:

T* p = &v.front

对于vector<bool>值来说,并不适用。

除此之外,由于vector<bool>通过代理对象进行存取访问时需要执行逐位处理,访问速度通常比int之类的普通类型操作要慢很多。
 因此,对vecotr<bool>的使用需慎重考虑以下几点:
(1)是否需要牺牲速度来获取空间上的优化
(2)算法中会否有对vecotr地址进行解引用操作的可能

        如果不满足以上条件,建议使用deque<bool>或vector<int>来取代vector<bool>,功能基本相同,但deque<bool>未对其进行特殊处理。

转载于:https://my.oschina.net/shou1156226/blog/881239

最后

以上就是贪玩星星最近收集整理的关于C++ 不使用vector的原因和替代方法的全部内容,更多相关C++内容请搜索靠谱客的其他文章。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(127)

评论列表共有 0 条评论

立即
投稿
返回
顶部