Dessecting c++ 阅读笔记 四

来源:互联网 发布:2k18球员数据库 编辑:程序博客网 时间:2024/04/29 20:01

1 new 与 malloc

c++ 风格的new 与 c 风格的alloc 都是为了分配内存,但是前者比后者的优点就是new 不但配置对象所需的内存空间,同时会引发构造函数的执行。

2 一个有着类层次的类群组,当派生类的对象诞生之时,构造函数的执行是由最基类(most based)至最尾端派生类(most derived ) ; 当对象要销毁之前,析构函数的执行则反其道而行之。

3 对于new 分配的堆对象,如果不显示的调用delete ,则该对象的析构函数的是不会执行的。但是要注意,虽然析构函数没有执行,但是该对象所占的内存空间已经被OS回收了

4 程序的内存泄露不是指程序退出后该程序申请的资源没有被os回收(现代的OS不会这么设计的),而是说在程序运行的时候,不断地分配内存空间,而且分配的内存对于该程序来说都不知道哪里去了(没有指向该内存的指针)。

5 我们不应当寄希望于进程推出后,OS帮我们回收该进程非配的资源,而是应该在编程的时候养成使用delete 的风格。

6 对于局部静态对象,当程序结束时析构函数才会执行,但是比全局对象的析构函数执行的早一点。

 

7 关于全局对象与静态全局对象的区别

全局对象本身就是“静态”存储方式(区别于auto 自动存储方式), 静态全局对象当然也是静态存储方式。 这两者在存储方式上并无不同。这两者的区别虽在于非静态全局对象的作用域是整个源程序,当一个源程序由多个源文件组成时,非静态的全局对象在各个源文件中都是有效的。 而静态全局对象则限制了其作用域, 即只在定义该对象的源文件内有效, 在同一源程序的其它源文件中不能使用它。由于静态全局对象的作用域局限于一个源文件内,只能为该源文件内的函数公用,因此可以避免在其它源文件中引起错误。
从以上分析可以看出, 把局部对象改变为静态对象后是改变了它的存储方式即改变了它的生存期。把全局对象改变为静态对象后是改变了它的作用域,限制了它的使用范围。因此static 这个说明符在不同的地方所起的作用是不同的。

原创粉丝点击