C++ 智能指针的使用

简介:  测试环境:win7, vs2012  如果未安装boost,请参考:http://blog.csdn.net/alex_my/article/details/17630685  涉及智能指针:shared_ptr, weak_ptr, scoped_ptr, auto_ptr  其它:enable_shared_from_this  总调用函数: testSmartPointer

 测试环境:win7, vs2012

 如果未安装boost,请参考:http://blog.csdn.net/alex_my/article/details/17630685

 涉及智能指针:shared_ptr, weak_ptr, scoped_ptr, auto_ptr

 其它:enable_shared_from_this

 总调用函数: testSmartPointer()

 可以将其放在main()中运行。解释在代码中。

#include <string>
#include <vector>
#include <iostream>
#include <boost/scoped_ptr.hpp>
#include <boost/shared_ptr.hpp>
#include <boost/weak_ptr.hpp>
#include <boost/enable_shared_from_this.hpp>

class Base
{
public:
	explicit Base(int a)
	: m_a(a)
	{
	}
	virtual ~Base()
	{
	}

	int GetA() const
	{
		return m_a;	
	}

private:
	int m_a;
};

class Derive : public Base
{
public:
	explicit Derive(int b)
		: Base(2 * b)
		, m_b(b)
	{

	}

	virtual ~Derive()
	{
	}

	int GetB() const
	{
		return m_b;	
	}

private:
	int m_b;
};

class EnableShared
{
public:
	EnableShared()
	: m_e(3)
	{

	}
	~EnableShared() 
	{
		std::cout<< "EnableShared Destruction execute" << std::endl;
	}

	void ShowE()
	{
		boost::shared_ptr<EnableShared> p1(this);
		std::cout<< p1->m_e << std::endl;
	}

private:
	int m_e;
};

class EnableSharedEx : public boost::enable_shared_from_this<EnableSharedEx>
{
public:
	EnableSharedEx()
		: m_e(3)
	{

	}
	~EnableSharedEx() 
	{
		std::cout<< "EnableSharedEx Destruction execute" << std::endl;
	}

	void ShowE()
	{
		//boost::shared_ptr<EnableSharedEx> p1(this);
		boost::shared_ptr<EnableSharedEx> p1 = shared_from_this();
		std::cout<< p1->m_e << std::endl;
	}

private:
	int m_e;
};

static void testSharedPtr();
static void testEnableSharedFromthis();
static void testScopedPtr();
static void testAutoPtr();

void testSmartPointer()
{
	// ------------- shared_ptr -------------
	testSharedPtr();

	// ------------- enable_shared_from_this -------------
	testEnableSharedFromthis();

	// ------------- scoped_ptr -------------
	testScopedPtr();

	// ------------- auto_ptr -------------
	testAutoPtr();

	// ------------- summary -------------
	// 1 auto_ptr会转移所有权,使原拥有者失效
	// 2 shared_ptr比起auto_ptr,不会转移所有权,而是增加引用计数
	// 3 scoped_ptr不允许复制
	// 4 weak_ptr起了类似于观察者的作用,不会对拥有者造成影响
}

void testSharedPtr()
{
	// 1 使用
	boost::shared_ptr<Base> pa(new Base(2));
	std::cout<< "testSharedPtr" << pa->GetA() << std::endl;

	// 2 发生引用,此时pa2和pa指向同一个指针,观察计数器share_ptr::use_count_ 值从1变为2。
	boost::shared_ptr<Base> pa2 = pa;

	// 3 弱引用,计数器并仍然是2,不过weak_count_ 从1变成了2。
	boost::weak_ptr<Base> p3 = pa;
}

void testEnableSharedFromthis()
{
	// 1 应用举例
	boost::shared_ptr<EnableShared> pe(new EnableShared);
	//pe->ShowE();

	// 2 注释说明
	// 编译可以通过,但是析构函数会执行两次,造成程序崩溃
	// shared_ptr的一个缺点,无法从this指针构造,无法像testSharedPtr中的引用例子一样。

	// 3 解决办法 enable_shared_from_this,改写EnableShared为EnableSharedEx
	boost::shared_ptr<EnableSharedEx> pex(new EnableSharedEx);
	pex->ShowE();
}

void testScopedPtr()
{
	// 1 应用举例、
	boost::scoped_ptr<Base> pb(new Base(2));
	std::cout << "testScopedPtr" << pb->GetA() << std::endl;

	// 2 引用,无法通过编译,原因:scope_ptr不允许复制
	// boost::scoped_ptr<Base> pb2 = pb;
}

void testAutoPtr()
{
	// 1 应用举例,与shared_ptr相似
	std::auto_ptr<Base> pa(new Base(2));
	std::cout<< "testAutoPtr: " << pa->GetA() << std::endl;

	// 2 发生引用,与shared_ptr不同的地方在于pa编程空指针了。
	std::auto_ptr<Base> pax = pa;
}

不懂它的时候,你觉的它是洪水猛兽。了解它的时候,会觉得它是那么的亲切。

相关文章
|
28天前
|
存储 编译器 Linux
【c++】类和对象(上)(类的定义格式、访问限定符、类域、类的实例化、对象的内存大小、this指针)
本文介绍了C++中的类和对象,包括类的概念、定义格式、访问限定符、类域、对象的创建及内存大小、以及this指针。通过示例代码详细解释了类的定义、成员函数和成员变量的作用,以及如何使用访问限定符控制成员的访问权限。此外,还讨论了对象的内存分配规则和this指针的使用场景,帮助读者深入理解面向对象编程的核心概念。
66 4
|
2月前
|
存储 安全 编译器
在 C++中,引用和指针的区别
在C++中,引用和指针都是用于间接访问对象的工具,但它们有显著区别。引用是对象的别名,必须在定义时初始化且不可重新绑定;指针是一个变量,可以指向不同对象,也可为空。引用更安全,指针更灵活。
|
2月前
|
存储 C++
c++的指针完整教程
本文提供了一个全面的C++指针教程,包括指针的声明与初始化、访问指针指向的值、指针运算、指针与函数的关系、动态内存分配,以及不同类型指针(如一级指针、二级指针、整型指针、字符指针、数组指针、函数指针、成员指针、void指针)的介绍,还提到了不同位数机器上指针大小的差异。
54 1
|
2月前
|
存储 编译器 C语言
C++入门2——类与对象1(类的定义和this指针)
C++入门2——类与对象1(类的定义和this指针)
39 2
|
2月前
|
存储 安全 编译器
【C++】C++特性揭秘:引用与内联函数 | auto关键字与for循环 | 指针空值(一)
【C++】C++特性揭秘:引用与内联函数 | auto关键字与for循环 | 指针空值
|
2月前
|
存储 C++ 索引
C++函数指针详解
【10月更文挑战第3天】本文介绍了C++中的函数指针概念、定义与应用。函数指针是一种指向函数的特殊指针,其类型取决于函数的返回值与参数类型。定义函数指针需指定返回类型和参数列表,如 `int (*funcPtr)(int, int);`。通过赋值函数名给指针,即可调用该函数,支持两种调用格式:`(*funcPtr)(参数)` 和 `funcPtr(参数)`。函数指针还可作为参数传递给其他函数,增强程序灵活性。此外,也可创建函数指针数组,存储多个函数指针。
|
3月前
|
编译器 C++
【C++核心】指针和引用案例详解
这篇文章详细讲解了C++中指针和引用的概念、使用场景和操作技巧,包括指针的定义、指针与数组、指针与函数的关系,以及引用的基本使用、注意事项和作为函数参数和返回值的用法。
51 3
|
2月前
|
存储 编译器 程序员
【C++】C++特性揭秘:引用与内联函数 | auto关键字与for循环 | 指针空值(二)
【C++】C++特性揭秘:引用与内联函数 | auto关键字与for循环 | 指针空值
|
3月前
|
C++
C++(十八)Smart Pointer 智能指针简介
智能指针是C++中用于管理动态分配内存的一种机制,通过自动释放不再使用的内存来防止内存泄漏。`auto_ptr`是早期的一种实现,但已被`shared_ptr`和`weak_ptr`取代。这些智能指针基于RAII(Resource Acquisition Is Initialization)原则,即资源获取即初始化。RAII确保对象在其生命周期结束时自动释放资源。通过重载`*`和`-&gt;`运算符,可以方便地访问和操作智能指针所指向的对象。
|
3月前
|
C++
C++(九)this指针
`this`指针是系统在创建对象时默认生成的,用于指向当前对象,便于使用。其特性包括:指向当前对象,适用于所有成员函数但不适用于初始化列表;作为隐含参数传递,不影响对象大小;类型为`ClassName* const`,指向不可变。`this`的作用在于避免参数与成员变量重名,并支持多重串联调用。例如,在`Stu`类中,通过`this-&gt;name`和`this-&gt;age`明确区分局部变量与成员变量,同时支持链式调用如`s.growUp().growUp()`。