Understanding the pythonic way: why a.x = 1 is better than a.setX(1) ?

Diez B. Roggisch deets at nospam.web.de
Fri Sep 5 11:23:10 EDT 2008


Ivan Illarionov schrieb:
> On 4 сент, 21:49, Bruno Desthuilliers
> <bdesth.quelquech... at free.quelquepart.fr> wrote:
>> Ivan Illarionov a écrit :
>>
>>
>>
>>> On 4 сент, 22:59, Carl Banks <pavlovevide... at gmail.com> wrote:
>>>> You can write code to guard against this if you want:
>>>> class A:
>>>>     legal = set(["x"])
>>>>     def __setattr__(self,attr,val):
>>>>         if attr not in self.legal:
>>>>             raise AttributeError("A object has no attribute '%s'" %
>>>> attr)
>>>>         self.__dict__[attr] = val
>>>>     def __init__(self,x):
>>>>         self.y = x
>>>> I suspect most people who go into Python doing something like this
>>>> soon abandon it when they see how rarely it actually catches anything.
>>> '__slots__' is better:
>> For which definition of "better" ? __slots__ are a mean to optimize
>> memory usage, not to restrict dynamism. Being able to dynamically add
>> arbitrary attributes is actually a feature, not a bug, and uselessly
>> restricting users from doing so is not pythonic. IOW : don't do that.
> 
> Carl's example is restricting dynamism in the same way as __slots__.
> I've just suggested a better implementation. It is not me who
> suggested dynamism restriction as a way to guard against errors.

This is not correct. While Carl's Example looks similar, you actually
*can* create new attributes using

obj.__dict__['name'] = value

__slots__ OTOH prevents that because it does create instances *without*
an instance-dict.

This being said, I think we all agree that it's nothing to be desired.


Diez



More information about the Python-list mailing list