《C++标准程序库》读书笔记 2012-07-08 auto_ptr 作为参数传递

《C++标准程序库》中说明auto_ptr当需要作为参数传递时,安全的方式是使用const T&方式

分析如下:
对于使用by value方式传递,不管使用T或者const T,ownership都会改变
对于使用by reference,若仅仅使用T&,虽然传参的时候没有改变ownership,但是在函数内部用户却可以随便改变ownership

援引书中的示例:

template <class T>
void bad_print(const std::auto_ptr<T>& p)
{
	//does p own an object?
	if (p.get() == NULL) {
		std::cout << "NULL";
	}
	else {
		std::cout << *p;
	}

	std::auto_ptr<T> tmp = p;	//COMPILE-TIME ERROR
}
template <class T>
void bad_print2(std::auto_ptr<T>& p)
{
	//does p own an object?
	if (p.get() == NULL) {
		std::cout << "NULL";
	}
	else {
		std::cout << *p;
	}

	std::auto_ptr<T> tmp = p;
}int main()
{	
	std::auto_ptr<int> p(new int);
	*p = 42;		//change value to which p refers
	//bat_print(p);		//COMPILE-TIME ERROR
	bad_print2(p);		
	*p = 18;		//RUNTIME ERROR
	return 0;
}

调用bad_print2,编译没有错误,但是运行的时候,因为std::auto_ptr<T> tmp = p;语句会改变p的ownership,在语句*p = 18;就会发生RUNTIME ERROR。
调用bad_print,编译就会报错,因为语句std::auto_ptr<T> tmp = p;改变了p的ownership。

这也能说明为什么auto_ptr不能用在STL的容器,书中是这样解释,对于C++标准程序库的所有容器的接口都使用的是const T&,然后在内部使用赋值操作,类似语句std::auto_ptr<T> tmp = p;
这样编译的时候就会报错,所以auto_ptr不能用于STL的容器。

备注:
auto_ptr作为类成员,应该是用const T

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值