单例模式是一种在设计中很常用的模式,通过static函数创建一个对象,以后的所有的数据都通过该函数操作,保持数据唯一,用起来也很方便,但是有个小小的问题,就是单例对象的释放问题,一般我们都是程序退出的时候统一释放对象,但是这并不是特别完美,有时候你可能会忘记调用,然后就发生了内存泄露,当然,现代操作系统会对每个程序进行内存管理,程序销毁的时候,这个程序所创建申请的内存资源都会被回收,不过这是后话,我们当然还是应该编写没有内存泄露的程序。
众所周知,C++这门语言并没有其他一些语言里的垃圾回收机制,程序员需要手动管理内存,指针很强大,但是操作不好的时候,也容易产生问题…下面提供一种单例对象的自动内存释放的方法,可以用在程序设计里,很方便,最关键的是内存可以做到自动释放啦:-)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
|
/*
* Singleton.h
*
* Created on: May 10, 2012
* Author: IceCoffee
*/
#include "vld.h"
#include <iostream>
class
Singleton
{
public
:
~Singleton()
{
std::cout <<
" ~Singleton()"
<< std::endl;
}
static
Singleton* Instance()
{
if
(m_pSingleton == nullptr)
{
m_pSingleton =
new
Singleton();
}
return
m_pSingleton;
}
private
:
class
AutoRelease
{
public
:
~AutoRelease()
{
if
(Singleton::m_pSingleton != nullptr)
{
delete
Singleton::m_pSingleton;
Singleton::m_pSingleton = nullptr;
}
}
};
private
:
static
Singleton* m_pSingleton;
static
AutoRelease m_auto;
};
Singleton* Singleton::m_pSingleton = nullptr;
Singleton::AutoRelease Singleton::m_auto;
int
main()
{
Singleton::Instance();
//此处只是一个调用单例模式的演示
return
0;
}
|
以上,
说明一下,这段代码之所以能做到自动内存释放,是因为使用了一个技巧,上面用内部类定义的m_auto是一个静态变量,而静态变量的生成和释放都是操作系统负责调用的,这样在m_auto销毁的时候,会自动进入m_auto的析构函数,即AutoRelease类的析构函数,我们在这个函数里进行释放单例对象的操作,这样就可以做到自动释放了
ps:”vld.h”是一款检测内存泄露的插件,可以在程序运行后在控制台输出窗口显示出相关内存泄露信息,下载地址:http://www.codeproject.com/Articles/9815/Visual-Leak-Detector-Enhanced-Memory-Leak-Detectio