std::vector 两种操作的比较

  • swap
  • assign
这里只想说明这三种操作的用处和效率。swap和assign都可以用在将一个vector的内容全部复制给另外一个vector,区别是swap会改变源vector,而assign会清空目的vector后再将源vector的值全部插入到目的vector中。就效率而言,swap只是交换vector的头指针,时间复杂度是常数;而assigin时间复杂度则是线性。

#include <vector>
#include "DebugUtility.h"
#include <iostream>
#include <algorithm>
#include <string>

using namespace std;

void print(int x)
{
    cout << x << endl;
}

void Swap(vector<string>& source, vector<string>& dest)
{
    DebugUtility temp;
    dest.swap(source);
}

void Assign(vector<string>& source, vector<string>& dest)
{
    DebugUtility temp; 
    dest.assign(source.begin(), source.end());
}

int main(int argc, const char *argv[])
{
    vector<string> source(900000, "90");
    vector<string> destination(1, "abc");

    Swap(source, destination);
    //source.clear();
    //for_each(destination.begin(), destination.end(), print);

    //Assign(source, destination);
    //source.clear();
    //for_each(destination.begin(), destination.end(), print);

    return 0;
}

结果:

Total time elapsed : 1 us
900000

Total time elapsed : 12391 us
900000

DebugUtility.h  大家可以从https://github.com/TimBao/Material.git/Utility取得。

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值