c语言标准库 swap,标准库如何实现std :: swap?

如何在STL中实现交换功能?

哪个实施?这是一个规范,而不是一个单独的具体库。如果你的意思是我的编译器的标准库是如何做的那样,要么告诉我们是哪个编译器,要么自己阅读代码。

这么简单:

这基本上是C ++ 11之前的天真版本。

这种非专业化的实施会强制复制:对于您的示例中的T = std::vector,代码转换为:

template void swap(T& t1, T& t2) {

T tmp(t1); // duplicate t1, making an expensive copy of each element

t1=t2; // discard the original contents of t1,

// and replace them with an expensive duplicate of t2

t2=tmp; // discard the original contents of t2,

// and replace them with an expensive duplicate of tmp

} // implicitly destroy the expensive temporary copy of t1

所以为了交换两个向量,我们基本上创建了三个。有三个动态分配和许多昂贵的对象被复制,任何这些操作都可能抛出,可能会使参数处于不确定的状态。

由于这显然很糟糕,为昂贵的容器提供了重载,并鼓励您为自己的昂贵类型编写重载:例如。 std::vector专门化可以访问向量的内部,并且可以在没有复制的情况下交换两个向量:

template void swap(vector &v1, vector &v2) { v1.swap(v2); }

template void vector::swap(vector& other) {

swap(this->size_, other.size_); // cheap integer swap of allocated count

swap(this->used_, other.used_); // cheap integer swap of used count

swap(this->data__, other.data_); // cheap pointer swap of data ptr

}

请注意,这不涉及任何昂贵的任何副本,没有动态(de)分配,并且保证不会抛出。

现在,这种专业化的原因是vector :: swap可以访问vector的内部,并且可以安全有效地移动它们而无需复制。

为什么我需要这样做[专门为你自己的班级]?

Pre-C ++ 11,出于与std::vector相同的原因 - 使交换高效且异常安全。

从C ++ 11开始,你真的没有 - 如果你提供移动构造和赋值,或者编译器可以为你生成合理的默认值。

新的通用交换:

template void swap(T& t1, T& t2) {

T temp = std::move(t1);

t1 = std::move(t2);

t2 = std::move(temp);

}

可以使用移动构造/赋值来获得与上面的自定义向量实现基本相同的行为,而无需编写自定义实现。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值