Heim  >  Artikel  >  Backend-Entwicklung  >  So erreichen Sie Polymorphismus in Go Without Inheritance: Ein praktisches Beispiel

So erreichen Sie Polymorphismus in Go Without Inheritance: Ein praktisches Beispiel

DDD
DDDOriginal
2024-11-18 20:44:02502Durchsuche

How to Achieve Polymorphism in Go Without Inheritance: A Practical Example

Polymorphismus in Go verstehen: Häufige Missverständnisse entlarven

Obwohl Polymorphismus ein grundlegendes Konzept in der objektorientierten Programmierung ist, nimmt er in andere Formen an Gehen. Lassen Sie uns die Angelegenheit klären, indem wir ein spezifisches Problem im Zusammenhang mit der Implementierung von Polymorphismus in Ihrem Code ansprechen.

In Go wird Polymorphismus durch Schnittstellen erreicht, die eine Reihe von Methoden definieren, die ein Typ implementieren muss. Anstatt Vererbung wie in objektorientierten Sprachen zu verwenden, verwendet Go Komposition, um Typen mit gemeinsamem Verhalten zu erstellen.

In Ihrem Code versuchen Sie, einen „Basis“-Typ BaseTX zu erstellen, der gemeinsame Felder für verschiedene Typen enthält von Transaktionen. Allerdings sollte Zusammensetzung anstelle von Vererbung verwendet werden, daher erstellen wir eine Metadatenstruktur, die die gemeinsam genutzten Felder speichert:

type Metadata struct {
    Field1 string
    Field2 string
}

Unsere Transaktionstypen werden dann Metadaten einbetten:

type RewardTX struct {
    Metadata 
}

type AllowanceTX struct {
    Metadata 
    AddField string
}

Um allgemeine Vorgänge für diese Transaktionstypen durchzuführen, definieren wir eine „logicAndSaveTX“-Methode für Metadaten, die die gemeinsame Verarbeitung verarbeitet Logik:

func (tx Metadata) logicAndSaveTX() {
    // Logic on Metadata fields
    tx.Field1 = "overwritten"
    tx.Field2 = "logic done"
}

Und dann definieren Sie benutzerdefinierte LogicAndSaveTX-Methoden für RewardTX und AllowanceTX, die das allgemeine Verhalten erweitern:

func (tx RewardTX) logicAndSaveTX() {
    // Call Metadata's logicAndSaveTX()
    tx.Metadata.logicAndSaveTX()

    // Additional logic unique to RewardTX
}

func (tx AllowanceTX) logicAndSaveTX() {
    // Call Metadata's logicAndSaveTX()
    tx.Metadata.logicAndSaveTX()

    // Additional logic unique to AllowanceTX
    tx.AddField = "more stuff"
}

Durch das Zusammenstellen von Metadaten in Transaktionstypen und das Implementieren spezifischer Methoden für jeden Typ, Wir erreichen das gewünschte Verhalten, ohne auf Vererbung oder Basisklassen angewiesen zu sein. Dies ist der „richtige Go-Weg“, um Polymorphismus durch Schnittstellen und Komposition zu handhaben.

Das obige ist der detaillierte Inhalt vonSo erreichen Sie Polymorphismus in Go Without Inheritance: Ein praktisches Beispiel. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn