3

Adobe Alchemy似乎没有运行全局构造函数。下面是一些简单的测试代码:

#include <stdio.h>

class TestClass {
public:
    TestClass(const char message[]) {
        printf("hello %s \n", message);
    }
};

TestClass global("global");

int main(int argc, char **argv) {
    TestClass local("local");
    printf("in main\n");
    return 0;
}

当使用本机 gcc 编译时,它输出:

hello global
hello local
in main

当使用 alchemy gcc 编译时,它会输出:

hello local
in main

这个问题破坏了很多代码,尤其是UnitTest++(这取决于初始化全局变量以使其自动测试列表功能正常工作)。

我真的很想弄清楚这一点。它是一个错误还是一个没有及时实现发布的功能?是否有可能解决?

编辑: Adob​​e 论坛上的相关帖子在这里

4

1 回答 1

2

我遇到了同样的问题。据我所知,情况似乎是这样:

如果即使单个类在其初始化期间的任何时候尝试动态分配,每个类类型的静态和全局变量都将静默初始化失败。 大概这是因为用于动态内存的 ByteBuffer 尚不可用。我希望 Alchemy 的错误消息更清楚,因为目前它就像一串老式圣诞灯,一个死灯会导致整个灯串关闭。

作为一种解决方法,一旦您发现了有问题的对象,您需要以某种方式将其初始化推迟到运行时。想到的三种技术是指针、惰性求值函数或对使用placement new 初始化的缓冲区的引用。

指针

// `global` is now a pointer
TestClass *global;

// all global variable initialization is found here now
void init_globals() {
  global = new TestClass("global");
}

int main(int argc, char **argv) {
  // this needs to be explicitly called at the start Alchemy
  init_globals();

然后你需要重构你的代码,改变每次出现的globalto (*global)

功能

// `global` is now a function
TestClass& global() {
  // static locals are initialized when their functions are first called
  static TestClass global_("global");
  return global_;
}

现在你需要用 替换每一次global出现global()。值得注意的是,这是这三种技术中唯一一种不需要显式init_globals调用的技术。global()我推荐这种方式,除非由于某种原因更改名称很麻烦......在这种情况下:

新的展示位置

// a memory buffer is created large enough to hold a TestClass object
unsigned char global_mem[sizeof(TestClass)];
// `global` is now a reference.  
TestClass& global = *(TestClass*)(void*)global_mem;

void init_globals() {
  // this initializes a new TestClass object inside our memory buffer
  new (global_mem) TestClass("global");
}

int main(int argc, char **argv) {
  init_globals();

这种方法的优点是您不需要更改任何其他代码,因为global仍然只是调用global. 不幸的是,维护一个init_globals函数可能很麻烦。


编辑:
正如在后面的问题中发现的那样,除了动态分配之外,在 Alchemy 的初始化期间也不能调用包含静态局部变量的函数。

于 2010-11-13T05:28:15.073 回答