VC c++中auto_ptr的转移问题
2007-10-10 09:15
417 查看
测试代码:
auto_ptr <int > ap(new int(1));
auto_ptr <int > ap2;
ap2=ap;
cout < < *ap2 < < "," < < *ap < < endl;
竟然都是1,说明没有转移啊。看了memory关于auto_ptr的赋值函数定义是这样的:
auto_ptr <_Ty >& operator=(const auto_ptr <_Ty >& _Y) _THROW0()
{if (this != &_Y)
{if (_Ptr != _Y.get())
{if (_Owns)
delete _Ptr;
_Owns = _Y._Owns; }
else if (_Y._Owns)
_Owns = true;
_Ptr = _Y.release(); }
return (*this); }
仅仅当指向不同对象的时候,才删除本auto_ptr的指针,然后赋值为另外的auto_ptr的指针。但是release方法的定义是:
_Ty *release() const _THROW0()
{((auto_ptr <_Ty > *)this)- >_Owns = false;
return (_Ptr); }
他不会删除指针,而是修改一个bool值为false。这个和标准库文档介绍的不同啊。没有实现转移,只是拷贝过去,修改一个bool值。这个难道是微软自己的实现?
auto_ptr <int > ap(new int(1));
auto_ptr <int > ap2;
ap2=ap;
cout < < *ap2 < < "," < < *ap < < endl;
竟然都是1,说明没有转移啊。看了memory关于auto_ptr的赋值函数定义是这样的:
auto_ptr <_Ty >& operator=(const auto_ptr <_Ty >& _Y) _THROW0()
{if (this != &_Y)
{if (_Ptr != _Y.get())
{if (_Owns)
delete _Ptr;
_Owns = _Y._Owns; }
else if (_Y._Owns)
_Owns = true;
_Ptr = _Y.release(); }
return (*this); }
仅仅当指向不同对象的时候,才删除本auto_ptr的指针,然后赋值为另外的auto_ptr的指针。但是release方法的定义是:
_Ty *release() const _THROW0()
{((auto_ptr <_Ty > *)this)- >_Owns = false;
return (_Ptr); }
他不会删除指针,而是修改一个bool值为false。这个和标准库文档介绍的不同啊。没有实现转移,只是拷贝过去,修改一个bool值。这个难道是微软自己的实现?
相关文章推荐
- C++:智能指针_auto_ptr_vc版本
- C++ 内存问题 auto_ptr
- 《The C++ Standard Library》第50页 关于传递auto_ptr的问题
- VC2005中的auto_ptr问题
- C++ auto_ptr智能指针的用法
- 关于auto_ptr_ref的一点问题
- 【C++】智能指针auto_ptr
- vc 下和Linux 下的auto_ptr源码剖析
- C++11 auto_ptr 的问题
- 关于auto_ptr_ref的一点问题
- 【C/C++】概念: VC虚函数布局引发的问题
- C++ auto_ptr 智能指针
- 【C++】智能指针auto_ptr的简单实现
- C++ auto_ptr的用法
- 《More Effective C++》学习心得(六) auto_ptr的用法
- 深入理解C++中的智能指针auto_ptr
- C++中灵巧指针auto_ptr
- auto_ptr、auto_ptr_ref及它们存在的问题
- C++智能指针,指针容器原理及简单实现(auto_ptr,scoped_ptr,ptr_vector).
- 【C/C++】智能指针auto_ptr,share_ptr,unique_ptr