• 为什么对string调用swap会导致迭代器失效


    一般来说,swap操作将容器内容交换不会导致容器的指针、引用、迭代器失效。

    但当容器类型为array和string时除外。

    原因在于:SSO  (Short String Optimization 指C++针对短字符串的优化。)

      默认情况下,C++的std::string都是存储在heap中,导致访问std::string需要经过一次寻址过程,速度较慢,并且这种实现的空间局部性不好,对cache的利用较低。

      很多string的字符串长度很小,这个时候,我们可以把字符串存储到栈上,从而不需要进行内存分配,优化创建速度,并且访问栈上数据的局部性很好,速度比较快。

    即C++会自动把较短的字符串放到对象内部,较长的字符串放到动态内存。
    假如 std::string 用 SSO 实现,而待交换的两个对象中的字符串恰好一长一短,则原先指向短字符串中的迭代器会全部失效。



  • 相关阅读:
    最长回文子串 leetcode
    leetcode Plus one
    n的阶乘末尾有几个0?
    求两数的最大公约数和最小公倍数
    汉诺塔
    求n的阶乘
    svn book
    求斐波那契数列第n项
    判断一个数是否是素数
    <C Traps and Pitfalls>笔记
  • 原文地址:https://www.cnblogs.com/ll-10/p/9633968.html
Copyright © 2020-2023  润新知