先将总结放在最前面:
1、在不考虑原数据的情况下,使用成员函数swap是最快的
2、尽量不要用循环遍历的方法,效率最低
3、根据需要可自行选择适合的方法
下面是实验测试代码。
// vector_copy.cpp : Defines the entry point for the console application.
//
#include "stdafx.h"
#include <vector>
#include <atlstr.h>
#include <time.h>
#include <iostream>
#include <algorithm>
using namespace std;
int _tmain(int argc, _TCHAR* argv[])
{
//assignment
vector<CString> vecSrc,vecDes;
for (int i=0;i<1000000;++i)
{
vecSrc.push_back("qianxin");
}
clock_t cb=clock();
//copy
//方法1 循环遍历 ----1050ms
/*for (int i=0;i<1000000;++i)
{
vecDes.push_back(vecSrc[i]);
}*/
//方法2 assign ----350ms
//vecDes.assign(vecSrc.begin(),vecSrc.end());
//方法3 swap ---1ms
//vecSrc.swap(vecDes);
//方法4 直接赋值 ----200ms
//vecDes=vecSrc;
//方法5 copy算法 ----644ms
//copy(vecSrc.begin(),vecSrc.end(),vecDes.begin()); //vecDes为空,越界
vector<CString> vec(1000000);
copy(vecSrc.begin(),vecSrc.end(),vec.begin());
clock_t ce=clock();
cout<<ce-cb<<endl;
system("pause");
return 0;
}