c++ 容器 swap

 swap交换函数: Exchange values of two objects.

c++11中说明如下:

This function is no longer defined in header <algorithm>, but in <utility>.
The behavior of these function templates is equivalent to:

template <class T> void swap (T& a, T& b)
{
  T c(std::move(a)); a=std::move(b); b=std::move(c);
}
template <class T, size_t N> void swap (T (&a)[N], T (&b)[N])
{
  for (size_t i = 0; i<N; ++i) swap (a[i],b[i]);
}

Many components of the standard library (within std) call swap in an unqualified manner to allow custom overloads for non-fundamental types to be called instead of this generic version: Custom overloads of swap declared in the same namespace as the type for which they are provided get selected through argument-dependent lookup over this generic version.

许多std库会特化实现.

 

可在特定场景下取代copy, 效率如下:

    vector<int>  vTest(100000, 9);
    auto tNow = TimeUtil::_GetTickCount64();
    for (int i = 100000; i > 0; i--){
        vector<int>  vDest;
        vDest = vTest;
    }
    tNow = TimeUtil::_GetTickCount64() - tNow;
    LOG_INF("copy  tc %d", tNow);
    tNow = TimeUtil::_GetTickCount64();
    for (int i = 100000; i > 0; i--){
        vector<int>  vDest;
        vDest.swap(vTest);
    }
    tNow = TimeUtil::_GetTickCount64() - tNow;
    LOG_INF("swap  tc %d", tNow);

输出:

2020-03-13 09:31:27.816 [13144][INF] copy  tc 14281
2020-03-13 09:31:28.016 [13144][INF] swap  tc 203

 

说明:个人学习,不定时更新

参考: http://www.cplusplus.com/reference/algorithm/swap/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值