析构先后顺序为:局部变量、mian函数中注册atexit函数、全局变量及在其中注册atexit函数(全局变量和在全局变量中注册atexit函数析构顺序与构造顺序相反)。测试代码如下(gcc-4.6.3编译, ubuntu 12.04 linux 内核3.2.0运行):
#include <cstdio>
#include <cstdlib>
#include <string>
#include <ctime>
static void PrintCurTime()
{
clock_t t = clock();
printf("past seconds %d\n", t);
}
static void exit_0()
{
printf("exit_0\n");
}
static void exit_1()
{
printf("exit_1\n");
}
class A
{
public:
A(const char* name)
{
m_name = name;
printf("A::A() %s\n", m_name);
}
~A()
{
printf("A::~A() %s\n", m_name);
double sum = 0;
const int n = 1<<28;
for (int i = 0; i < n; ++i)
sum += i*i;
}
const char* m_name;
};
class B
{
public:
B(const char* name)
{
m_name = name;
printf("B::B() %s\n", m_name);
atexit(exit_0);
}
~B(){printf("B::~B()