C++ Primer(第五版) 13.3节练习

13.29    swap(HasPtr&, HasPtr&)函数中调换的ps和i都是内置类型,会调用标准库std::swap,不会导致递归循环。

13.30    代码如下(operator=用swap实现):

#include <iostream>
#include <string>
#include <vector>
#include <algorithm>

using namespace::std;

class HasPtr {
	friend void swap(HasPtr&, HasPtr&);
public:
	HasPtr(const string &s = string()): 
		ps(new string(s)), i(0), use(new size_t(1)) { }
	HasPtr(const HasPtr &p):
		ps(new string(*p.ps)), i(p.i), use(p.use) { ++*use; }
	HasPtr& operator=(HasPtr);
	void str() {
		cout << *ps << endl;
	}
	~HasPtr();

private:
	string *ps;
	int i;
	size_t *use;	
};

inline 
void swap(HasPtr &lhs, HasPtr &rhs)
{
	using std::swap;
	
	cout << "swap function" << endl;
	
	swap(lhs.ps, rhs.ps);
	swap(lhs.i, rhs.i);
}

HasPtr&
HasPtr::operator=(HasPtr rhs)
{
	swap(*this, rhs);
	
	return *this;
}

HasPtr::~HasPtr()
{
	if ( --*use == 0 ) {
		delete ps;
		delete use;
	}
}

int main(int argc, char *argv[])
{
	HasPtr h1("dog");
	HasPtr h2("cat");
	HasPtr h3("rat");
	
	h1.str();
	h2.str();
	
	h2 = h1;
	h2.str();
	
	swap(h1, h3);
	h1.str();
	h3.str();

	return 0;
}

13.31 代码如下:

#include <iostream>
#include <string>
#include <vector>
#include <algorithm>

using namespace::std;

class HasPtr {
	friend void swap(HasPtr&, HasPtr&);
public:
	HasPtr(const string &s = string()): 
		ps(new string(s)), i(0), use(new size_t(1)) { }
	HasPtr(const HasPtr &p):
		ps(new string(*p.ps)), i(p.i), use(p.use) { ++*use; }
	HasPtr& operator=(HasPtr);
	bool operator<(const HasPtr&);
	void str() {
		cout << *ps << endl;
	}
	~HasPtr();

private:
	string *ps;
	int i;
	size_t *use;	
};

inline 
void swap(HasPtr &lhs, HasPtr &rhs)
{
	using std::swap;
	
	cout << "swap function" << endl;
	
	swap(lhs.ps, rhs.ps);
	swap(lhs.i, rhs.i);
}

HasPtr&
HasPtr::operator=(HasPtr rhs)
{
	swap(*this, rhs);
	
	return *this;
}

bool
HasPtr::operator<(const HasPtr &rhs)
{
	return *ps < *rhs.ps;
}

HasPtr::~HasPtr()
{
	if ( --*use == 0 ) {
		delete ps;
		delete use;
	}
}

int main(int argc, char *argv[])
{
	HasPtr h1("dog");
	HasPtr h2("cat");
	
	vector<HasPtr> hv = {h1, h2};
	for (auto h : hv)
		h.str();
		
	cout << "sort "<< endl;
	sort(hv.begin(), hv.end());

	for (auto h : hv)
		h.str();

	return 0;
}

13.32    类指针版本的HasPtr也会从swap收益,如上2题的代码所示,其赋值运算符也可以用swap来定义,无需处理use,因为二者互换后引用计数不变,都是先减1后加1。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值