Начиная с Java, я немного борюсь с наследованием, абстрактными классами, статическими методами и схожими понятиями программирования OO в Python.
У меня есть реализация дерева дерева выражений, данная (упрощенная) с помощью
# Generic node class
class Node(ABC):
@abstractmethod
def to_expr(self):
pass
@staticmethod
def bracket_complex(child):
s = child.to_expr()
return s if isinstance(child, Leaf) or isinstance(child, UnaryOpNode) else "(" + s + ")"
# Leaf class - used for values and variables
class Leaf(Node):
def __init__(self, val):
self.val = val
def to_expr(self):
return str(self.val)
# Unary operator node
class UnaryOpNode(Node):
def __init__(self, op, child):
self.op = op
self.child = child
def to_expr(self):
return str(self.op) + super().bracket_complex(self.child)
# Binary operator node
class BinaryOpNode(Node):
def __init__(self, op, lchild, rchild):
self.op = op
self.lchild = lchild
self.rchild = rchild
def to_expr(self):
return super().bracket_complex(self.lchild) + " " + str(self.op) + " " + super().bracket_complex(self.rchild)
# Variadic operator node (arbitrary number of arguments)
# Assumes commutative operator
class VariadicOpNode(Node):
def __init__(self, op, list_):
self.op = op
self.children = list_
def to_expr(self):
return (" " + str(self.op) + " ").join(super().bracket_complex(child) for child in self.children)
Метод to_expr()
отлично работает при вызове экземпляров Leaf
, UnaryOpNode
и BinaryOpNode
, но вызывает TypeError
при вызове экземпляра VariadicOpNode
:
TypeError: super(type, obj): obj must be an instance or subtype of type
Что я делаю неправильно в этом конкретном классе, который super()
внезапно не работает?
В Java статический метод получил бы унаследованный, поэтому мне даже не понадобился бы супервызов, но в Python это, похоже, не так.