插件的初始化程序问题.测试

initalizer problem with plugins. a test

本文关键字:问题 测试 程序 初始化 插件      更新时间:2023-10-16

我有一个更长更复杂的问题,下面的代码http://www.ideone.com/VEOvp

不过,我会简化它。下面的代码有什么问题吗?有更好的方法吗?

我担心这行std::list<Plugin*>& plugins,以及如何在保留它作为参考的同时设置它。但我会让你们把代码拆开。

#include <list>
#include <string>
class Plugin{
public:
    static std::list<Plugin*>*plugins;
    std::string name;
    Plugin(const std::string&n) : name(n)
    {
      static std::list<Plugin*> plugins;
      this->plugins=&plugins;
      plugins.push_back(this);
    }
};
//main.cpp
#include "plugin.h"
class Plugin1 : public Plugin{
public:
    Plugin1():Plugin("1"){}
};
static Plugin1 plugin;

std::list<Plugin*>* Plugin::plugins;
std::list<Plugin*>& plugins = *Plugin::plugins; //global name plz
int main(){
    for(auto c=plugins.cbegin(); c!=plugins.cend(); ++c) {
        printf("%sn", (*c)->name.c_str());
    }
}
//PluginA.cpp
#include "plugin.h"
class PluginA : public Plugin{
public:
    PluginA():Plugin("A"){}
};
static PluginA plugin;

我觉得这很奇怪。如果你的目标是拥有某种全局插件容器/管理器,有没有理由不使用这样的单一模式:

class PluginContainer {
    static PluginContainer& instance() 
    { 
        static PluginContainer* m_this = 0;
        if(!m_this) 
             m_this = new PluginContainer;
        return *m_this;
    }
    void register(Plugin* plugin) { ... add to a list ... }
    const list<Plugin*>& plugins() const { ... return it ... }
    protected:
        PluginContainer() {}
};
class Plugin{
    public:
    Plugin(const std::string& n) : name(n)
    {
         PluginContainer::instance().register( this );
    }
    private:
    std::string name;
};

我修改了2行并添加了ForceInit。它应该是安全的,但未经证实。

Plugin(const std::string&n) : name(n){ static std::list<Plugin*> plugins; this->plugins=&plugins; if(n.length()==0) return; plugins.push_back(this); }
static std::list<Plugin*>* ForceInit() { Plugin d(""); return plugins; }
std::list<Plugin*>& plugins = *Plugin::ForceInit(); //global name plz