一个例子记住C++对象的生存周期
作者:网络转载 发布时间:[ 2016/4/11 11:47:11 ] 推荐标签:.NET C++
近要考C++,复习过程中遇到一些问题,总结记录一下。文中代码均在ideone在线编译器中运行的。
代码
代码说明:
类A,含构造函数和析构函数
普通函数fun,函数体里新建了类A的局部自动对象FunObj和局部静态对象InStaObj
main方法新建了类A的局部自动对象MainObj,调用fun方法
外面新建了A的的外部静态对象ExStaObj和外部对象GblObj
#include <iostream>
#include <string.h>
using namespace std;
class A {
char string[50];
public :
A(char * st);
~A( );
};
A::A(char * st)
{
strcpy(string, st);
cout << string << "被创建时调用构造函数 ! " << endl;
}
A::~A( )
{
cout << string <<
"被撤消时调用析构函数 ! " << endl;
}
void fun( )
{
cout << "在fun( )函数体内 :
" << endl;
A FunObj("fun( )函数体内的自动对象FunObj");
static A InStaObj("内部静态对象InStaObj");
}
int main( )
{
A MainObj("主函数体内的自动对象MainObj");
cout<<"主函数体内,调用fun()函数前:
";
fun( );
cout << "
主函数体内,调用fun()函数后:
";
return 0;
}
static A ExStaObj("外部静态对象ExStaObj");
A GblObj("外部对象GblObj");
输出:
外部静态对象ExStaObj被创建时调用构造函数 !
外部对象GblObj被创建时调用构造函数 !
主函数体内的自动对象MainObj被创建时调用构造函数 !
主函数体内,调用fun()函数前:
在fun( )函数体内 :
fun( )函数体内的自动对象FunObj被创建时调用构造函数 !
内部静态对象InStaObj被创建时调用构造函数 !
fun( )函数体内的自动对象FunObj被撤消时调用析构函数 !
主函数体内,调用fun()函数后:
主函数体内的自动对象MainObj被撤消时调用析构函数 !
内部静态对象InStaObj被撤消时调用析构函数 !
外部对象GblObj被撤消时调用析构函数 !
外部静态对象ExStaObj被撤消时调用析构函数 !
若将A GblObj("外部对象GblObj"); 写在static A ExStaObj("外部静态对象ExStaObj");前面,则输出时两者顺序也颠倒。
分析
创建顺序
外部静态对象or外部对象优先于main函数
销毁顺序
和创建顺序相反,注意静态对象会在main函数执行完才会销毁
内存的三种分配方式
从静态存储区分配:此时的内存在程序编译的时候已经分配好,并且在程序的整个运行期间都存在。全局变量,static变量等在此存储
在栈区分配:相关代码执行时创建,执行结束时被自动释放。局部变量在此存储。栈内存分配运算内置于处理器的指令集中,效率高,但容量有限
在堆区分配:动态分配内存。用new/malloc时开辟,delete/free时释放。生存期由用户指定,灵活。但有内存泄露等问题
相关推荐
更新发布
功能测试和接口测试的区别
2023/3/23 14:23:39如何写好测试用例文档
2023/3/22 16:17:39常用的选择回归测试的方式有哪些?
2022/6/14 16:14:27测试流程中需要重点把关几个过程?
2021/10/18 15:37:44性能测试的七种方法
2021/9/17 15:19:29全链路压测优化思路
2021/9/14 15:42:25性能测试流程浅谈
2021/5/28 17:25:47常见的APP性能测试指标
2021/5/8 17:01:11