大家都知道,全局对象的生命周期是整个Process,Process终了时系统回收空间,全局对象的构造是在main()函数之前,析构是在main()函数返回后进行的。今天发现在VC6.0和VC2012中是有区别的。
(1)测试代码:
文件a.h,a.cpp,main.h,main.cpp代码如下
#pragma once
class A
{
public:
A();
~A();
};
#include <iostream>
#include "a.h"
A::A()
{
std::cout << "A construct.\n";
}
A::~A()
{
std::cout << "A deconstruct.\n";
}
#pragma once
class B : public A
{
public:
B();
~B();
};
//author:chen_jintao
//注意:includeの使い方、順序
#include <iostream>
#include "a.h"
#include "main.h"
B::B()
{
std::cout << "B construct.\n";
}
B::~B()
{
std::cout << "B deconstruct.\n";
}
B theB;//全局对象定义
void main()
{
std::cout << "main() function is over.\n";
return;
}
(2)测试结果:
a)VC6.0中的执行结果:
b)VC2012中执行结果:
(3)结果分析:
从VC6.0的执行结果来看A、B的析构函数没有调用,其实析构函数确实是调用了,这是VC6.0对C++标准库支持的一个bug。这是因为std这个对象在main函数退出后已经释放掉了,所以A、B析构函数的“std::cout<<”没有输出。
大家可以用下面2种方式去确认:
1.直接使用include<iostream.h>代替include<iostream>,调用cout<<。
2.用的C++封装的C的标准库,include<cstdio>或者直接include<stdio.h>,调用printf()。