[Python-Dev] subclassing builtin data structures

Serhiy Storchaka storchaka at gmail.com
Fri Feb 13 23:31:14 CET 2015


On 13.02.15 05:41, Ethan Furman wrote:
> So there are basically two choices:
>
> 1) always use the type of the most-base class when creating new instances
>
>     pros:
>       - easy
>       - speedy code
>       - no possible tracebacks on new object instantiation
>
>     cons:
>       - a subclass that needs/wants to maintain itself must override all
>         methods that create new instances, even if the only change is to
>         the type of object returned
>
> 2) always use the type of self when creating new instances
>
>     pros:
>       - subclasses automatically maintain type
>       - much less code in the simple cases [1]
>
>     cons:
>       - if constructor signatures change, must override all methods which
>         create new objects

And switching to (2) would break existing code which uses subclasses 
with constructors with different signature (e.g. defaultdict).

The third choice is to use different specially designed constructor.

class A(int):

>>> class A(int):
...     def __add__(self, other): 

...         return self.__make_me__(int(self) + int(other)) 
 

...     def __repr__(self): 

...         return 'A(%d)' % self
...
>>> A.__make_me__ = A
>>> A(2) + 3
A(5)
>>> class B(A):
...     def __repr__(self):
...         return 'B(%d)' % self
...
>>> B.__make_me__ = B
>>> B(2) + 3
B(5)

We can add special attribute used to creating results of operations to 
all basic classes. By default it would be equal to the base class 
constructor.



More information about the Python-Dev mailing list