primer c++笔记第二十天
动态对象的正确释放被证明是编程中极其容易出错的地方。为了更安全使用动态对象,标准库定义了两个智能指针类型来管理动态分配的对象。
静态内存用来保存局部static对象,类static数据成员以及任何定义在任何函数之外的变量
栈内存用来保存定义在函数内的非static对象。分配在静态或栈内存中的对象由编译器自动创建和销毁。
对于栈对象,仅在其定义的程序块运行时才存在;static对象在使用前分配,在程序结束时销毁
除了静态内存和栈内存,每个程序还拥有内存池。这部分被称作自由空间(free store)或堆(heap)。
为了更容易的使用动态内存,新的标准库提供了两种智能指针(smart pointer)类型来管理动态对象。
智能指针的行为类似常规指针,重要的区别是他负责自动释放所指向的对象。
share_ptr允许多个指针指向同一个对象
unique_ptr则“独占”所指向的对象
weak_ptr的伴随类,他是一种弱引用,指向shared_ptr所管理的对象
最安全的分配和使用动态内存的方法是调用一个名make_shared的标准库函数。此函数在动态内存中分配一个对象并初始化他。
share_ptr的析构函数会递减它所指向的对象的引用计数。如果引用计数变为0,share_ptr的析构函数就会销毁对象,并释放他占用的内存。
对于一块内存,shared_ptr类只要有任何shared_ptr对象引用他,它就不会被释放掉。
程序使用动态内存处于以下三种原因之一:
1.程序不知道自己需要使用多少对象
2.程序不知道所需要对象的准确类型
3.程序需要多个对象间共享数据
同一块内存释放两次。当有两个指针指向相同的动态分对象分配时。可能发生这种错误。如果对其中一个指针进行了delete操作,对象的内存就被归还给自由空间了。如我我们随后又delete第二个指针,自由空间就别破坏了。
坚持使用智能指针,就可以避免所有这些问题。对于一块内存,只有在没有任何智能指针指向它的情况下,智能指针才会自动释放它。