C/C++ 中静态变量初始化的问题归根节点在于一点:静态变量的使用和初始化可能位于不同的 translation unit(Effective C++),因此可能会出现使用位于初始化之前的情况,而这种情况是不可控的,可能这次编译初始化部分位于使用部分之前,而下次编译可能就相反了。
【禁止或不推荐】用函数返回值初始化静态变量
int func()
{
return 50;
}
void test()
{
static int i = func();
}
int main()
{
test();
return 0;
}
这段代码用 C 写是编译出错的,因为 C 中静态变量如果在声明时(其实也是定义时,因为如果不显式赋值,编译器会默认填 0)显式赋初值,那么值必须是在编译阶段就能确定的,也就是说只能是字面常量,也即是说即使是用另一个变量初始化它也不行。
(C99, 6.7.8p4) "All the expressions in an initializer for an object that has static storage duration shall be constant expressions or string literals."