Die Macht von Defer in Go ausnutzen
In Go bietet die „defer“-Anweisung einen einzigartigen Ansatz für die Planung von Funktionsaufrufen. Es ermöglicht Entwicklern, Code anzugeben, der unmittelbar vor der Rückkehr der umfassenden Funktion ausgeführt werden soll. Sie fragen sich jedoch vielleicht, warum diese Funktionalität von Vorteil ist, wenn Sie den Code einfach am Ende der Funktion platzieren können.
Im Gegensatz zu Code, der am Ende der Funktion positioniert ist, wird bei verzögerten Funktionsaufrufen garantiert, dass sie auch in ausgeführt werden der Fall einer Panik. Gewöhnliche Funktionsaufrufe würden in solchen Situationen übersprungen.
Darüber hinaus ermöglicht defer verzögerten Funktionsaufrufen die Bewältigung von Paniken durch Nutzung der integrierten „Wiederherstellungs“-Funktionalität. Diese Funktion ist für reguläre Funktionsaufrufe nicht verfügbar.
Verzögerte Funktionsaufrufe werden gestapelt und nach Abschluss der umgebenden Funktion in umgekehrter Reihenfolge ausgeführt. Diese Reihenfolge gewährleistet die ordnungsgemäße Freigabe der Ressourcen. Es ist jedoch wichtig zu beachten, dass verzögerte Funktionsaufrufe vom Erreichen der auszuführenden „defer“-Anweisung abhängen.
Die Konzeptualisierung von „defer“ als alternative Implementierung von Try-Catch-finally-Blöcken kann hilfreich sein. Es bietet eine elegante Möglichkeit, Bereinigungsaufgaben und Panikbehandlungen durchzuführen.
Das folgende Beispiel zeigt beispielsweise das ordnungsgemäße Schließen einer Datei mithilfe von „defer“:
func main() { f, err := os.Create("file") if err != nil { panic("cannot create file") } defer f.Close() // no matter what happens here file will be closed // for sake of simplicity I skip checking close result fmt.Fprintf(f,"hello") }
Erweitern des Beispiels auf Beinhaltet Panikbehandlung und -wiederherstellung:
func main() { defer func() { msg := recover() fmt.Println(msg) }() f, err := os.Create(".") // . is a current directory if err != nil { panic("cannot create file") } defer f.Close() // no matter what happens here file will be closed // for sake of simplicity I skip checking close result fmt.Fprintf(f,"hello") }
Im Gegensatz zu Try-Catch-Finally-Blöcken vereinfacht „Defer“ die Struktur der umgebenden Funktion um Eliminierung der Verschachtelung und Vereinfachung der Variablenbereiche. Darüber hinaus können verzögerte Funktionsaufrufe den Rückgabewert beeinflussen, wenn sie auf die zurückgegebenen Daten zugreifen können, was für mehr Flexibilität sorgt.
Das obige ist der detaillierte Inhalt vonWarum die „Defer'-Anweisung von Go für garantierte Bereinigung und Wiederherstellung nach Panik verwenden?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!