从类(不是类成员)scop访问类对象内置值

2024-06-25 06:43:33 发布

您现在位置:Python中文网/ 问答频道 /正文

如何从顶级类范围内访问类值?我的意思是,你是怎么做的

class FooClass(object):
    zeroith_base = __bases__[0]
    .
    .
    .

在本例中,我特别尝试的是派生所有基类的元类,以动态生成一个元类,该元类将所有基类的元类进行子类化,从而解决metclass冲突问题。我发现了http://code.activestate.com/recipes/204197-solving-the-metaclass-conflict/,虽然所有的概念对我来说都是有意义的,但是食谱的实际代码超出了我的能力。我不想使用我不懂的代码,所以我试着实现我自己的,更基本的系统,但是在创建过程中我被困在试图检查类对象的第一步。你知道吗


Tags: 代码httpbaseobjectcode动态基类顶级
2条回答

您会发现__bases__不是类命名空间的一部分。类命名空间作为第三个参数传递给元类;基作为第二个参数传递。在创建类之前,它们是完全分开的。你知道吗

所以您需要做的是编写一个元类来合成所需的元类,然后使用它来创建类。我不知道这是否真的管用,但我看不出有什么理由不管用

您不能在类创建之前检查它,并且在语句套件或类主体完成执行之前它还没有被创建。您第一次能够访问这些信息是在创建有问题的类的类的MetaClass.__new__方法中,或者是在创建有问题的类的事物的执行中,从技术上讲,它们根本不需要是元类或类(如下例所示)。你知道吗

这是一个非常粗略的原型,可能并不适用于所有情况,但适用于简单的情况,可能比配方更容易遵循。你知道吗

def meta_class_synthesize(name, bases, attrmap):
    seen = set()
    seen_add = seen.add
    metas = [type(base) for base in bases]
    metas = tuple([
        meta for meta in metas
        if meta is not type and meta not in seen and not seen_add(meta)])
    if not metas:
        return type(name, bases, attrmap)
    elif len(metas) == 1:
        return metas[0](name, bases, attrmap)
    newmeta_name = "__".join(meta.__name__ for meta in metas)
    newmeta = type(newmeta_name, metas, {})
    return newmeta(name, bases, attrmap)

class M_A(type):
    pass

class M_B(type):
    pass

class A:
    __metaclass__ = M_A

class B:
    __metaclass__ = M_B

class C(A, B):
    __metaclass__ = meta_class_synthesize


print type(C)  # prints "<class '__main__.M_A__M_B'>"

相关问题 更多 >