// 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; }
版权声明:本文博客原创文章,博客,未经同意,不得转载。