C++primer 5th中说到STL容器
其中array与其他容器的不同点:
1.swap的使用
swap的作用:交换两个相同类型的元素内容如:
vector a{0};
vector b{1};
vector ::iterator iter=a.begin();
swap(a,b);
此时你访问迭代器,*iter的值应该是0.因为元素不会被移动,swap不对任何元素进行拷贝、删除或者插入操作,因此可以保证其在常数时间内完成。
此外,array和string(String 我在VS2015试了,没有失效,但是查阅了资料:
原因在于:SSO (Short String Optimization 指C++针对短字符串的优化。)
默认情况下,C++的std::string都是存储在heap中,导致访问std::string需要经过一次寻址过程,速度较慢,并且这种实现的空间局部性不好,对cache的利用较低。
很多string的字符串长度很小,这个时候,我们可以把字符串存储到栈上,从而不需要进行内存分配,优化创建速度,并且访问栈上数据的局部性很好,速度比较快。
即C++会自动把较短的字符串放到对象内部,较长的字符串放到动态内存。
假如 std::string 用 SSO 实现,而待交换的两个对象中的字符串恰好一长一短,则原先指向短字符串中的迭代器会全部失效。
);
此外Array的不同:例如:
array<int, 10> a = { 0 };
array<int, 10>::iterator iter = a.begin();
cout << *iter << endl;
array<int, 10> b = { 1 };
swap(a, b);
cout << *iter << endl;
此时的array的迭代器还是为0,所以array的操作快慢与元素大小成正比。