当前位置: 代码迷 >> 综合 >> C++STL std::swap
  详细解决方案

C++STL std::swap

热度:1   发布时间:2023-12-08 09:14:14.0

有如下两个类 当前需要交换两个Widget对象

class WidgetImpl{
public:
private:
int a,b,c;
std::vector<double>v;
};
class Widget{
public:
Widget(const Widget& rhs);
Widget& operator=(const Widget& rhs)
{
*pImpl=*(rhs.pImpl);
}
private:
WidgetImpl* pImpl;
};

交换两个Widget对象值 可以直接置换其pImpl指针 但std::swap置换算法并不知道这一点
它会复制三个Widgets,三个WidgetImpl对象 (temp=a;a=b;b=temp;)
因此我们需要对std::swap做特例化来实现我们的优化


namespace std{
template<>
void swap<Wideget>(Widget& a,Widget& b){
swap(a.pImpl,b.pImpl);
}

这个版本当前会有编译错误 原因是pImpl是private数据成员
特例化版本无法获得访问类内成员的权限
接下来如若考虑将该特例化版本设计为friend function
但根据条款23 封装性与提供的弹性变化成正比,与改动破坏性成反比.
friend function提供的封装性显然不足
不利于后续的改动 所以作一下的优化
考虑使用一个public的 Widget::swap(Widget& other)function进行指针交换
并作std::swap的特例化版本调用函数
此方法可以提升了类的封装性

Widget类的交换指针函数的实现如下

void 	Widget::swap(