Tag: 基类的

GCC问题:使用依赖于模板参数的基类成员

下面的代码不能用gcc编译,而是用Visual Studio编译: template <typename T> class A { public: T foo; }; template <typename T> class B: public A <T> { public: void bar() { cout << foo << endl; } }; 我得到的错误: test.cpp:在成员函数'void B :: bar()'中: test.cpp:11:错误:'foo'未在此范围内声明 但应该是! 如果我改变bar void bar() { cout << this->foo << endl; } 那么它编译,但我不认为我必须这样做。 在C ++的官方规范中是否有这样的东西,GCC在这里,还是只是一个怪癖?

在Python中创build一个单例

这个问题不是讨论单例devise模式是否合意,是反模式还是任何宗教战争,而是讨论如何在python中最好的实现这种模式。 在这种情况下,我把“最pythonic”定义为遵循“最不惊讶的原则” 。 我有多个类将成为单身(我的用例是一个logging器,但这不是重要的)。 当我可以简单地inheritance或装饰时,我不希望杂乱地加上几个类似的东西。 最好的方法: 方法1:一个装饰器 def singleton(class_): instances = {} def getinstance(*args, **kwargs): if class_ not in instances: instances[class_] = class_(*args, **kwargs) return instances[class_] return getinstance @singleton class MyClass(BaseClass): pass 优点 装饰器是以一种比多重inheritance更直观的方式添加的。 缺点 虽然使用MyClass()创build的对象将是真正的单例对象,MyClass本身是一个函数,而不是一个类,所以你不能从它调用类的方法。 另外对于m = MyClass(); n = MyClass(); o = type(n)(); m = MyClass(); n = MyClass(); o = type(n)(); 那么m […]