Есть ли объяснение использования источника в функции (self, source) для классов отношений HAS-A в python? - PullRequest
0 голосов
/ 24 октября 2019

Может ли кто-нибудь объяснить или ссылаться на документацию для объяснения источника в качестве аргумента в функциях, которые используются в отношениях HAS-A?

Я пытаюсь улучшить свои знания об ООП в python, таким образом, учась у: https://runestone.academy/runestone/books/published/pythonds/Introduction/ObjectOrientedProgramminginPythonDefiningClasses.html#inheritance-logic-gates-and-circuits. Существует пример наследования классов и использования композиции (1.13.2. Наследование: логические элементы и схемы). Я не могу понять фон «источника» как аргумент функции следующего кода. В режиме отладки я вижу, что весь экземпляр класса передается в качестве аргумента. Является ли «источник» зарезервированным словом? В приведенном ниже коде - class Connector HAS-A class LogicGate и функция ссылки tgate.setNextPin(self), но в классе BinaryGate есть def setNextPin(self,source), и моя проблема связана со ссылкой на источник.

class LogicGate:
    def __init__(self,n):
        self.name = n
        self.output = None

    def getLabel(self):
        return self.name

    def getOutput(self):
        self.output = self.performGateLogic()
        return self.output


class BinaryGate(LogicGate):
    def __init__(self,n):
        super(BinaryGate, self).__init__(n)
        self.pinA = None
        self.pinB = None

    def getPinA(self):
        if self.pinA == None:
            return int(input("Enter Pin A input for gate "+self.getLabel()+"-->"))
        else:
            return self.pinA.getFrom().getOutput()

    def getPinB(self):
        if self.pinB == None:
            return int(input("Enter Pin B input for gate "+self.getLabel()+"-->"))
        else:
            return self.pinB.getFrom().getOutput()

    def setNextPin(self,source):
        if self.pinA == None:
            self.pinA = source
        else:
            if self.pinB == None:
                self.pinB = source
            else:
                print("Cannot Connect: NO EMPTY PINS on this gate")

class AndGate(BinaryGate):
    def __init__(self,n):
        BinaryGate.__init__(self,n)

    def performGateLogic(self):
        a = self.getPinA()
        b = self.getPinB()
        if a==1 and b==1:
            return 1
        else:
            return 0

class UnaryGate(LogicGate):
    def __init__(self,n):
        LogicGate.__init__(self,n)
        self.pin = None

    def getPin(self):
        if self.pin == None:
            return int(input("Enter Pin input for gate "+self.getLabel()+"-->"))
        else:
            return self.pin.getFrom().getOutput()

    def setNextPin(self,source):
        if self.pin == None:
            self.pin = source
        else:
            print("Cannot Connect: NO EMPTY PINS on this gate")

class NotGate(UnaryGate):
    def __init__(self,n):
        UnaryGate.__init__(self,n)

    def performGateLogic(self):
        if self.getPin():
            return 0
        else:
            return 1

class Connector:
    def __init__(self, fgate, tgate):
        self.fromgate = fgate
        self.togate = tgate
        tgate.setNextPin(self)

    def getFrom(self):
        return self.fromgate

    def getTo(self):
        return self.togate

def main():
   g1 = AndGate("G1")
   g2 = NotGate("G2")
   c1 = Connector(g1,g2)
   print(g2.getOutput())

main()
...