// Test.cpp : 自定义控制台应用程序的入口点。
// #include "stdafx.h"
#include <iostream>
#include <memory> //注意加这个头文件
using namespace std; class Widdget
{
}; int priority()
{
return 0;
}
/*
以下的函数可能造成内存泄露:
调用的时候例如以下: processWiddget(std::tr1::shared_ptr<Widdget>(new Widdget), priority());
这里的 std::tr1::shared_ptr<Widdget>(new Widdget)由两部分组成
1:运行new Widdget表达式
2:调用tr1::shared_ptr构造函数
再加上priority()函数,在调用processWiddget()之前。编译器必须创建代码,做一下三件事情:
调用priority()函数
运行“new Widdget”
调用tr1::shared_ptr构造函数
C++编译器对这三个调用顺序不是固定的,能够确定的是new Widdget一定运行于tr1::shared_ptr构造函数之前,由于
new Widdget的结果要作为构造函数的一个參数,可是对于priority的调用排在哪个顺序就不知道了
可能是:
1:new Widdget
2:调用priority()
3:调用tr1::shared_ptr构造函数
这里假设priority调用出现了异常没那么new Widdget的指针将会遗失掉, 造成资源泄露。 解决的方法非常easy:
使用分离语句:
(1):创建Widdget
(2):讲它置入一个智能指针内。然后再调用processWiddget
std::tr1::shared_ptr<Widdget> pw(new Widdget);//单独语句内以智能指针存储newed所得对象
processWiddget(pw,priority()) 以独立语句将newed对象存储于智能指针,假设不这样做,一旦发生异常可能导致内存泄露
在VC6.0中不能使用tr1::shared_ptr */ void processWiddget(std::tr1::shared_ptr<Widdget> pw, int priority())
{ } int _tmain(int argc, _TCHAR* argv[])
{
return 0;
}
版权声明:本文博客原创文章,博客,未经同意,不得转载。