c – 静态初始化命令fiasco

c – 静态初始化命令fiasco,第1张

概述在他的“C中思考”(第10章)中,Eckel介绍了杰里·施瓦茨(Jerry Schwarz)率先采用的技术来解决这一失败. 他说,如果我们要将x初始化为100并将y分配到200,并在所有翻译单元之间共享,我们创建一个如下所示的Initializer.h: extern int x;extern int y;class Initializer { static int initCount; 在他的“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 – 静态初始化命令fiasco全部内容,希望文章能够帮你解决c – 静态初始化命令fiasco所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/1250073.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-07
下一篇 2022-06-07

发表评论

登录后才能评论

评论列表(0条)

保存