1.赋值
赋值运算符定义:将左边容器的全部元素替换为右边容器中的拷贝
c1 = c2 //case1
c = {a,b,c,d...} //case2
全部元素的意思是:全部元素,而不包括大小、类型,| 迭代器、引用和指针。
所以我们在使用的时候必须保证大小和类型必须一致,以array为例
case1:
array<int , 10> a1{0,1,2,3,4,5,6,7,8,9};
array<int , 20> a2(a1); //error
array<int , 10> a2(a1); //true
case2:
array<int, 10>a2{0};
a2 = {1,2,3,4,5,6,7,8,9,1};
在C++primer书上是说array不允许使用花括号包围的值列表赋值但是,我运行输出的结果就是1,2,3,4,5,6,7,8,9,1(还是不要用吧!!!不能纠结这个说不用就是不用)
note:关于左边容器的迭代器、引用和指针,会失效(我的理解是:失效就是没有指向原来的元素了,而是新的元素)到了swap那也会聊这个问题。
1.2 assign(只有顺序容器初array以外)
赋值只允许容器的大小和类型具有相同的类型,为了使不同但是相融的类型赋值,我们推出了assign这种成员函数。
seq.assign(b,e); //seq中的元素替换为迭代器b和e所表示的范围中的元素
seq.assign(i1); //
seq.assign(n,t); //替换为n个t
我们可以类比到容器的定义和初始化那,array禁止使用。
2.使用swap(array可用只是慢而已)
vector<string> svec1(10);
vector<string> svec2(24);
swap(svec1 , svec2);
swap的定义是容器内的元素并未交换,只是交换了,内部的数据结构(迭代器、引用和指针)
swap的迭代器、引用和指针不会失效验证了我的猜想!!!(如果以后发现不对了是真的尴尬)
两个例外,string和array
一般来说,swap操作将容器内容交换不会导致容器的指针、引用、迭代器失效。
但当容器类型为array和string时除外。
原因在于:SSO (Short String Optimization 指C++针对短字符串的优化。)
默认情况下,C++的std::string都是存储在heap中,导致访问std::string需要经过一次寻址过程,速度较慢,并且这种实现的空间局部性不好,对cache的利用较低。
很多string的字符串长度很小,这个时候,我们可以把字符串存储到栈上,从而不需要进行内存分配,优化创建速度,并且访问栈上数据的局部性很好,速度比较快。
即C++会自动把较短的字符串放到对象内部,较长的字符串放到动态内存。
假如 std::string 用 SSO 实现,而待交换的两个对象中的字符串恰好一长一短,则原先指向短字符串中的迭代器会全部失效。【抄的,反正我没看懂,留到之后用到了在研究】
array是真的会交换容器的元素。