クラスA
のすべてのインスタンスの__dict__
がグローバルdict shared
を指すこの例を考えてみましょう。予想通りクラスで__dict__属性をオーバーライドした後にインスタンス辞書にアクセスするには?
>>> a = A()
>>> b = A()
>>> a.a, a.b, b.a, b.b
(1, 2, 1, 2)
>>> b.x = 100
>>> shared
{'a': 1, 'x': 100, 'b': 2}
>>> a.x
100
>>> c = A()
>>> c.a, c.b, c.x
(1, 2, 100)
>>> shared['foo'] = 'bar'
>>> a.foo, b.foo, c.foo
('bar', 'bar', 'bar')
>>> a.__dict__, b.__dict__, c.__dict__
({'a': 1, 'x': 100, 'b': 2, 'foo': 'bar'},
{'a': 1, 'x': 100, 'b': 2, 'foo': 'bar'},
{'a': 1, 'x': 100, 'b': 2, 'foo': 'bar'}
)
すべての作品:
shared = {'a': 1, 'b': 2}
class A(object):
def __init__(self):
self.__dict__ = shared
今度は、いくつかのことをテストしてみましょう。
今度は__dict__
という名前の属性を追加することにより、クラスA
少し微調整しましょう。
shared = {'a': 1, 'b': 2}
class A(object):
__dict__ = None
def __init__(self):
self.__dict__ = shared
のは、再びステップの同じセットを実行してみましょう:上記の情報に基づいて
>>> a = A()
>>> b = A()
>>> a.a, a.b, b.a, b.b
AttributeError: 'A' object has no attribute 'a'
>>> b.x = 100
>>> shared
{'a': 1, 'b': 2}
>>> b.__dict__ # What happened to x?
{'a': 1, 'b': 2}
>>> a.x
AttributeError: 'A' object has no attribute 'x'
>>> c = A()
>>> c.a, c.b, c.x
AttributeError: 'A' object has no attribute 'a'
>>> shared['foo'] = 'bar'
>>> a.foo, b.foo, c.foo
AttributeError: 'A' object has no attribute 'foo'
>>> a.__dict__, b.__dict__, c.__dict__
({'a': 1, 'b': 2, 'foo': 'bar'},
{'a': 1, 'b': 2, 'foo': 'bar'},
{'a': 1, 'b': 2, 'foo': 'bar'}
)
>>> b.x # Where did this come from?
100
予想通り最初のケースが働いていたが、二番目はしなかったので、私はしたいと思います追加クラスレベル__dict__
の属性の後で何が変更されたかを知る。今使用されているインスタンス辞書にはどのような方法でもアクセスできますか?
:
第二ケースを継続します。 [**予約済みクラスの識別子**](https://docs.python.org/3/reference/lexical_analysis.html#reserved-classes-of-identifiers)を参照してください。 – martineau
@martineau私はそれを認識しています。しかし、それはこの問題のポイントではありません。 –
ガイドラインに従わないために壊れていたものの回避策を知りたがっています。 – martineau