容器与拷贝构造函数的问题

定义一个vector<string>, 在其上多次调用push_back.观察string被拷贝了多少次

在未指定vector大小的时候,第一次push_back操作会调用一次元素的拷贝构造函数(此时vectord的capacity为1)

在第二次调用push_back时,容量不够,此时vector会重新分配capacity为原来的2倍

vector会调用一次旧元素(第一个)的拷贝构造函数将它移到新内存上,同时旧内存会被释放掉。

新元素也会有一次拷贝构造的过程。

如果在push-back之前,提前分配了足够的内存,就可以避免这样的情况。

 

posted @ 2017-11-21 22:31  三二二,  阅读(258)  评论(0编辑  收藏  举报