博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
C++构造与析构(18) - 静态对象(static object)何时销毁
阅读量:4071 次
发布时间:2019-05-25

本文共 1527 字,大约阅读时间需要 5 分钟。

目录


1.C++的static关键字

static关键字可以用于修改局部变量,函数,类的数据成员以及对象。

静态局部变量只初始化一次,然后在每次函数调用时都保持它的值。
静态成员函数可以直接用类来调用,不需要创建对象来调用。
同时,C++也支持静态对象。

2.C++的静态对象

当使用static关键字声明一个对象时,此对象就变成了静态对象。见下面两个表达式。

Test t;             // 栈上的对象static Test t1;     // 静态对象

第一个表达式会在栈上分配一个对象,也被称为自动对象或局部对象。局部对象在每次声明它时就会创建。

而静态对象只初始化一次,并且在整个程序的生命周期中都存在。

静态对象保存在静态存储区。在程序结束时,它就会被销毁。C++既支持局部静态对象,也支持全局静态对象。

3.局部静态对象

下面例子演示了局部静态对象的使用

#include 
class Test {public: Test() { std::cout << "Constructor is executed\n"; } ~Test() { std::cout << "Destructor is executed\n"; }};void myfunc() { static Test obj;} // 函数结束时,obj不会被消耗,因为是静态对象。int main() { std::cout << "main() starts\n"; myfunc(); // 这里不会调用析构函数,因为函数体中分配的是静态对象。 std::cout << "main() terminates\n"; return 0;}

运行结果:

main() starts
Constructor is executed
main() terminates
Destructor is executed

从结果可以看到,只有在主函数main()结束时,才会调用到析构函数。

如果删除掉上面程序中的关键字static,则运行结果为:

main() starts
Constructor is executed
Destructor is executed
main() terminates

4.全局静态对象

参考下面例子

#include 
class Test {public: int a; Test() { a = 10; std::cout << "Constructor is executed\n"; } ~Test() { std::cout << "Destructor is executed\n"; }};static Test obj;int main() { std::cout << "main() starts\n"; std::cout << obj.a; //注意:静态对象可以调用它的所有成员,包括非静态成员。 //但如果是静态函数,则只能调用静态成员。 std::cout << "\nmain() terminates\n"; return 0;}

运行结果:

Constructor is executed
main() starts
10
main() terminates
Destructor is executed

转载地址:http://wheji.baihongyu.com/

你可能感兴趣的文章
postgresql中wal日志什么时候会触发归档
查看>>
Centos 6.8 上 DRBD安装和使用
查看>>
history查看历史操作记录,并显示操作时间
查看>>
postgresql修改完端口后直接psql连接数据库报错
查看>>
pl/proxy-2.5安装在postgresql9.6上无法编译
查看>>
postgresql遇到“Connection refused”和“No route to host”大概的解决方法
查看>>
postgresql上安装sysbench-0.5
查看>>
pgpool3.2.9中编译 pgpool-walrecrunning函数出错
查看>>
benchmarksql在postgresql上的安装、使用
查看>>
使用yum安装postgresql 10 dev
查看>>
postgresql减少wal日志生成量的方法
查看>>
postgresql使用RHCS套件搭建HA高可用集群
查看>>
postgresql initdb过程中大体做了什么
查看>>
linux下的mysql源码安装
查看>>
plsql连接oracle出现ORA-12154: TNS: 无法解析指定的连接标识符
查看>>
oracle 查看库中每个表所占的空间大小
查看>>
流复制中的问题max_connection
查看>>
在mysql中使用模糊查询时,使用中文查询结果不正确问题
查看>>
redhat7修改系统语言
查看>>
启动rabbitmq:ERROR: distribution port 25672 in use on localhost (by non-Erlang process?)
查看>>