同一种写法在Visual Studio和Mingw64出现了不同结果的问题
我编写了一个抽象类,这个抽象提供一个构造函数,用于将继承他的子类添加到静态集合中,关键代码如下:
抽象类:
子类:
我预计的结果是子类对象实例化后,可以将子类对象添加到父类的静态集合中。
由于第一次编写这段代码是在Visual Studio上,运行结果也跟我预计的一样,将子类的信息打印在控制台上。
由于Visual Studio打开速度等问题,再加上想了解GCC,于是我把上面的代码切换到使用Mingw64来进行编译,但是结果却是控制台中什么都没有。
编译命令:
g++ main.cpp test.cpp Demo.cpp -o main.exe
完整代码:
- main.cpp:
#include <iostream>
#include "test.h"
#include "Demo.h"
int main() {
Test::Print();
return 0;
}
- test.h:
#pragma once
#include <vector>
#include <string>
using std::vector;
using std::string;
class Test {
static vector<const Test*> collection;
public:
Test () = delete;
Test (const Test* subclass);
virtual const string Name() const = 0;
static void Print ();
};
- test.cpp:
#include "test.h"
#include <iostream>
using std::cout;
using std::endl;
vector<const Test*> Test::collection;
Test::Test(const Test* subclass) {
collection.push_back(subclass);
}
void Test::Print() {
for (auto subclass : collection) {
cout << "已注册:" << subclass->Name() << endl;
}
}
- Demo.h:
#pragma once
#include "test.h"
class Demo : public Test {
public:
Demo();
const string Name() const override;
};
- Demo.cpp:
#include "Demo.h"
Demo::Demo() : Test(this)
{
}
const string Demo::Name() const
{
return "Demo";
}
Demo demo;
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
因为Demo.h中定义的全局变量
demo
可以不被初始化。静态存储期的非局部变量的初始化在程序启动时进行,通常在main函数执行前完成,除非被推迟了。它们的初始化分成两类,静态初始化和动态初始化。其中动态初始化可能会被推迟,推迟与否取决于编译器实现。而被推迟的动态初始化可能不会被执行。这里
demo
的初始化属于动态初始化,所以不同编译器可以产生不同的结果。Deferred dynamic initialization最佳实践是避免程序依赖全局变量构造函数的副作用。而在真的需要这样一个可以全局访问的对象时,请用单例模式。