Was sind die Ursachen für Golang-Speicherlecks?
Die Gründe für das Leck sind: 1. Die Verwendung von time.After(duration x) generiert NewTimer(), bevor die Dauer x abläuft , GC; 2. time.NewTicker-Ressourcen werden nicht rechtzeitig freigegeben; 4. Kanalblockierung; 6. verursacht durch Slice;
Die Betriebsumgebung dieses Tutorials: Windows 7-System, GO Version 1.18, Dell G3-Computer.
Mehrere Situationen, in denen Golang leicht zu Speicherverlusten führen kann
1. Unsachgemäße Verwendung von Timern
1.1 Die Verwendung von time.After()
Die Standardeinstellung time.After() hat Speicher Das Problem ist durchgesickert, da NewTimer() jedes Mal generiert wird.After(Dauer
Mit der Zeit vergeht, insbesondere wenn die Dauer abnimmt. Bitte überprüfen Sie den Unterschied selbst oder lesen Sie meine vorherigen Artikel https://blog.csdn.net/weixin_38299404/article/details/119352884
for true { select { case <-time.After(time.Minute * 3): // do something default: time.Sleep(time.Duration(1) * time.Second) } }
1.2 time.NewTicker-Ressourcen werden nicht rechtzeitig freigegebenbei Verwendung von time.NewTicker Sie müssen die Stop()-Methode manuell aufrufen, um Ressourcen freizugeben, andernfalls kommt es zu einem dauerhaften Speicherverlust
2 AuswahlblockierungBei Verwendung Wählen Sie, wenn es einen Fall gibt, der nicht vollständig abgedeckt ist und es keinen Standardzweig für die Verarbeitung gibt. Dies führt schließlich zu Speicherverlusten.
2.1 Goroutine-Blockierung verursachen und Speicherlecks verursachen
2.2 Schleifenleerlauf verursacht CPU-Anstiegtimer := time.NewTicker(time.Duration(2) * time.Second) defer timer.Stop() for true { select { case <-timer.C: // do something default: time.Sleep(time.Duration(1) * time.Second) } }
Oben Sobald die for-Schleifenbedingung den Standardwert erreicht, wird die Schleife inaktiv und führt schließlich dazu, dass die CPU in die Höhe schnellen kann3 Die Kanalblockierung wird hauptsächlich in zwei Situationen unterteilt: Schreibblockierung und Leseblockierung Der gepufferte Kanal ist blockiert, weil der Puffer voll ist und der Schreibvorgang blockiert ist 4. Speicherverlust durch Goroutine 4.1 Anwenden von zu vielen Goroutinen
4.2 Goroutine-Blockierung
4.2.1 E/A-Problem
Die E/A-Verbindung legt kein Timeout fest, was dazu führt, dass die Goroutine weiter wartet und der Code weiterhin blockiert.4.2.2 Die Mutex-Sperre wird nicht freigegeben
- Goroutine kann die Sperrressource nicht erhalten, wodurch die Goroutine blockiert wird
timer := time.NewTicker(time.Duration(2) * time.Second) // defer timer.Stop() for true { select { case <-timer.C: // do something default: time.Sleep(time.Duration(1) * time.Second) } }
- 4.2.3 Deadlock
- Wenn zwei Slices gemeinsame Adressen haben, von denen eine eine globale Variable ist, kann die andere nicht GC sein. Es wurde nach dem Anhängen des Slice verwendet und nicht bereinigt.
func main() { ch1 := make(chan int) ch2 := make(chan int) ch3 := make(chan int) go Getdata("https://www.baidu.com",ch1) go Getdata("https://www.baidu.com",ch2) go Getdata("https://www.baidu.com",ch3) select{ case v:=<- ch1: fmt.Println(v) case v:=<- ch2: fmt.Println(v) } }
6. Wertübertragung von Arrays
Da Arrays der grundlegende Datentyp von Golang sind, belegt jedes Array einen anderen Speicherplatz und der Lebenszyklus stört sich nicht gegenseitig Wenn die Funktion von mehreren Goroutinen aufgerufen wird und das Array zu groß ist, führt dies zu einem Anstieg der Speichernutzung. func main() {
fmt.Println("main start")
msgList := make(chan int, 100)
go func() {
for {
select {
case <-msgList:
default:
}
}
}()
c := make(chan os.Signal, 1)
signal.Notify(c, os.Interrupt, os.Kill)
s := <-c
fmt.Println("main exit.get signal:", s)
}
Nach dem Login kopieren Daher werden Slices oder Zeiger normalerweise zum Übertragen großer Arrays in Szenarios mit formalen Parametern verwendet, um kurzfristige Speicherauslastungsspitzen zu vermeiden. [Verwandte Empfehlungen: Video-Tutorial ansehen,
Programmierunterricht]
Das obige ist der detaillierte Inhalt vonWas sind die Ursachen für Golang-Speicherlecks?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!
func main() { fmt.Println("main start") msgList := make(chan int, 100) go func() { for { select { case <-msgList: default: } } }() c := make(chan os.Signal, 1) signal.Notify(c, os.Interrupt, os.Kill) s := <-c fmt.Println("main exit.get signal:", s) }

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

Video Face Swap
Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen

Das Problem der Warteschlange Threading In Go Crawler Colly untersucht das Problem der Verwendung der Colly Crawler Library in Go -Sprache. Entwickler stoßen häufig auf Probleme mit Threads und Anfordern von Warteschlangen. � ...

In der Bibliothek, die für den Betrieb der Schwimmpunktnummer in der GO-Sprache verwendet wird, wird die Genauigkeit sichergestellt, wie die Genauigkeit ...

Der Unterschied zwischen Stringdruck in GO -Sprache: Der Unterschied in der Wirkung der Verwendung von Println und String () ist in Go ...

Das Problem der Verwendung von RETISTREAM zur Implementierung von Nachrichtenwarteschlangen in der GO -Sprache besteht darin, die Go -Sprache und Redis zu verwenden ...

Welche Bibliotheken in GO werden von großen Unternehmen oder bekannten Open-Source-Projekten entwickelt? Bei der Programmierung in Go begegnen Entwickler häufig auf einige häufige Bedürfnisse, ...

Was soll ich tun, wenn die benutzerdefinierten Strukturbezeichnungen in Goland nicht angezeigt werden? Bei der Verwendung von Goland für GO -Sprachentwicklung begegnen viele Entwickler benutzerdefinierte Struktur -Tags ...

Go Language funktioniert gut beim Aufbau effizienter und skalierbarer Systeme. Zu den Vorteilen gehören: 1. hohe Leistung: Kompiliert in den Maschinencode, schnelle Laufgeschwindigkeit; 2. gleichzeitige Programmierung: Vereinfachen Sie Multitasking durch Goroutinen und Kanäle; 3. Einfachheit: präzise Syntax, Reduzierung der Lern- und Wartungskosten; 4. plattform: Unterstützt die plattformübergreifende Kompilierung, einfache Bereitstellung.

Effizient behandeln Probleme mit der Parallelitätssicherheit beim Schreiben von Multi-Process-Protokoll. Mehrere Prozesse schreiben gleichzeitig die gleiche Protokolldatei. Wie kann die Parallelität sicher und effizient sichergestellt werden? Das ist ein ...
