Блокировать изменяемые объекты как неизменяемые в python

Как мне "заблокировать" объект в Python?

Скажем, у меня есть:

class Foo:
  def __init__(self):
    self.bar = []
    self.qnx = 10

Я бы изменил foo столько, сколько захочу:

foo = Foo()
foo.bar.append('blah')
foo.qnx = 20

Но тогда я хотел бы иметь возможность "заблокировать" его, чтобы при попытке

lock(foo)
foo.bar.append('blah')  # raises some exception.
foo.qnx = 20            # raises some exception.

Возможно ли это в Python?

Ответ 1

Вот простой способ сделать это.

class Foo(object):
    def __init__(self):
        self._bar = []
        self._qnx = 10
        self._locked= False

    @property
    def locked(self):
        return self._locked

    def lock(self):
        self._locked = True

    @property
    def bar(self):
        if self.locked:
            return tuple(self._bar)
        return self._bar

    @property
    def qnx(self):
        return self._qnx
    @qnx.setter
    def qnx(self,val):
        if self.locked:
            raise AttributeError
        self._qnx = val

def lock(obj):
    obj.lock()