Python с помощью метода производного класса в родительском классе?

Я могу вынудить родительский класс назвать версию производного класса функции?

class Base(object):
    attr1 = ''
    attr2 = ''

    def virtual(self):
        pass               # doesn't do anything in the parent class

    def func(self):
        print "%s, %s" % (self.attr1, self.attr2)
        self.virtual()

и класс, который происходит из него

class Derived(Base):
    attr1 = 'I am in class Derived'
    attr2 = 'blah blah'

    def virtual(self):
        # do stuff...
        # do stuff...

Разрешение неопределенности:

d = Derived()
d.func()         # calls self.virtual() which is Base::virtual(), 
                 #  and I need it to be Derived::virtual()
11
задан 19 February 2010 в 16:44
поделиться

2 ответа

Если вы создаете экземпляр Derived (скажем, d = Derived () ), то .virtual , вызываемый d.func () , является Derived.virtual . Если нет задействованного экземпляра Derived , то нет подходящего self для Derived.виртуальный и поэтому его конечно нельзя назвать.

9
ответ дан 3 December 2019 в 08:29
поделиться

Это не невозможно - на самом деле есть способ обойти это, и вам не нужно передавать функцию или что-то в этом роде. Я сам работаю над проектом, в котором возникла именно эта проблема. Вот решение:


class Base(): # no need to explicitly derive object for it to work
    attr1 = 'I am in class Base'
    attr2 = 'halb halb'

    def virtual(self):
        print "Base's Method"

    def func(self):
        print "%s, %s" % (self.attr1, self.attr2)
        self.virtual()

class Derived(Base):
    attr1 = 'I am in class Derived'
    attr2 = 'blah blah'

    def __init__(self):
  # only way I've found so far is to edit the dict like this
        Base.__dict__['_Base_virtual'] = self.virtual

    def virtual(self):
        print "Derived's Method"

if __name__ == '__main__':
    d = Derived()
    d.func()

5
ответ дан 3 December 2019 в 08:29
поделиться
Другие вопросы по тегам:

Похожие вопросы: