boost库在工作(2)作用域智能指针scoped_ptr之一
来源:互联网 发布:想开淘宝怎么找货源 编辑:程序博客网 时间:2024/06/03 17:00
很久远以前,丹尼斯.里奇发明了C语言,这个语言有一个优点,就是可以动态地分配内存。当需要使用内存时,就可以立即向系统申请。当不需要时,又可以立即释放回给系统,再给别的程序使用。这种动态的内存管理,使得当时以K计算的内存时代,也可以处理很大数据量的软件出现。但这中使用函数malloc来分配内存,使用函数free来释放内存的机制,一直到今天,还在使用。不过,这种方式有一个缺点,就是当你不断地使用函数malloc来分配内存,而忘记使用free函数来释放内存时,就会导致系统里的内存一点一点地变少了。
进入C++的开发时代,内存分配变成new和delete的操作,也提供了构造函数和析构函数,这样更进一步对内存管理的自动化,虽然这样比C语言时代提高了不少方便之处。但在C++里还有很多函数里分配的资源,在某些地方直接返回,忘记删除内存了,这时又有内存泄漏了。如下面的例子:
voidTest(void){ int* nVal = new int; if (*nVal > 0) { return; } delete nVal;}
上面的例子,只是几行代码,当然不会忘记的,但写一个函数的代码,往往有200行以上,更有人把函数的代码写到1000行或2000行以上,也大有人在。在这种情况之下,往往会忘记删除内存,导致泄漏出现了。
面对内存丢失的高风险,软件长时间运行不稳定而难以根除,软件的代码量又越来越大的今天,在C++的世界里急需寻找一个方案来解决这个问题,否则软件的开发成本会越来越高,软件发布的日期一推再推。有些开发人员,已经等不及这个方案出现,就转向了不用内存管理的语言世界,比如JAVA、C#,因为这些语言都是带有垃圾回收的机制,不再用软件开发人员去参与内存管理了。但这些语言是以降低软件运行性能为代价的,因为垃圾回收时,所有对象都不能运行,需要等到内存回收之后,才能运行。此外,垃圾的统计和标记,也增加了很大开销,导致系统变慢。
在C++的世界里,还有没有更好的方案来解决这个问题呢?答案是会有的,它既不引入垃圾回收的机制,也不会增加太多资源上的负担。在STL库里,为此引入了std::auto_ptr,这就是智能指针。
- boost库在工作(2)作用域智能指针scoped_ptr之一
- boost库在工作(2)作用域智能指针scoped_ptr之一
- boost库在工作(3)作用域智能指针scoped_ptr之二
- boost库在工作(4)作用域智能指针scoped_ptr之三
- boost库在工作(5)作用域智能指针scoped_ptr之四
- boost库在工作(6)作用域智能指针scoped_ptr之五
- boost库在工作(3)作用域智能指针scoped_ptr之二
- boost库在工作(4)作用域智能指针scoped_ptr之三
- boost库在工作(5)作用域智能指针scoped_ptr之四
- boost库在工作(6)作用域智能指针scoped_ptr之五
- 作用域指针 boost::scoped_ptr
- 智能指针boost::scoped_ptr
- Boost智能指针:scoped_ptr
- boost::scoped_ptr智能指针
- 详解Boost库智能指针(shared_ptr && scoped_ptr && weak_ptr )
- boost库:智能指针(auto_ptr、scoped_ptr、shared_ptr)浅谈
- 智能指针Boost.smart_ptr学习2--scoped_ptr
- boost库在工作(8)引用计数的智能指针shared_ptr之一
- source insight中添加.cc文件的支持
- Request&Response编程
- 【推荐】无线通信技术推荐学习图书目录
- boost库在工作(1)第一个例子
- Effective C++ 读书笔记(25)
- boost库在工作(2)作用域智能指针scoped_ptr之一
- Effective C++读书笔记(26)
- Leetcode Permutation II
- boost库在工作(3)作用域智能指针scoped_ptr之二
- 3364Lanterns (异或方程组高斯消元)
- boost库在工作(4)作用域智能指针scoped_ptr之三
- 避免代码注释的五大理由[转载]
- TCMalloc小记
- boost库在工作(5)作用域智能指针scoped_ptr之四