c – 静态初始化命令fiasco

前端之家收集整理的这篇文章主要介绍了c – 静态初始化命令fiasco前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
在他的“C中思考”(第10章)中,Eckel介绍了杰里·施瓦茨(Jerry Schwarz)率先采用的技术来解决这一失败.
他说,如果我们要将x初始化为100并将y分配到200,并在所有翻译单元之间共享,我们创建一个如下所示的Initializer.h:
extern int x;
extern int y;
class Initializer {
   static int initCount;
   // if (initCount++ == 0) x = 100 & y = 200
   /* ... */
};
static Initializer init;

在实现文件中我们有

#include "Initializer.h"
int x;
int y;
int Initializer::initCount;

Eckel说“静态初始化(在实现文件中)会强制所有这些值为零”.

让我考虑以下情况:编译器在包含该标题的其他文件之后处理实现文件(这意味着x和y已经在该另一个文件中已经设置为100和200).编译器看到int x,那么它会做什么?它会将x和y设置为零,以消除初始化和以前文件中的所有可能的更改?但是如果这样做,initCount也将被设置为零,从而打破整个技术.

解决方法

But if it is true,and the compiler handles the implementation file after some another file,than it will set x and y to zero eliminating initialization and all possible changes in prevIoUs files?

我不知道这是什么意思.如果x和y在其他文件中定义,那么你有一个链接器冲突,程序根本就不会编译.

如果x,y和最重要的是Initializer :: initCount以这种方式实现,程序中将会有唯一的实例;它们有效地是全局的,并且在程序启动之前,在构造任何初始化程序之前(由于包含声明该类的静态实例的头)而被初始化为0).静态初始化程序的每个构造将首先检查是否由于if(initCount == 0)等构造了任何其他Initializers.

因此,要运行的第一个初始化器ctor(仍然在进入main之前)将设置所有三个值.

猜你在找的C&C++相关文章