sync.waitgroup koordiniert die Goroutine -Fertigstellung durch Blockieren, bis alle Goroutinen mit Add, Fertig und Warten abgeschlossen sind. 2. Sync.Mutex und sync.rwmutex schützen gemeinsam genutzte Daten mit exklusiven oder gemeinsam genutzten Sperren, wobei RWMutex h?ufige Lesevorg?nge optimiert; A. context.context erm?glicht die Ausbreitung von Stornierungen und Frist über Goroutinen, withcancel, with timeout oder Withdeadline und immer anrufen, um Lecks zu verhindern. 4. Sync.once stellt sicher, dass eine Funktion genau einmal ausgeführt wird, ideal für die Initialisierung des globalen Zustands wie Datenbankverbindungen. 5. 6. Das Atomic-Paket bietet lockfreie Vorg?nge für Primitive wie Z?hler, die Funktionen wie AddInt64 und LoadInt64 verwenden, die nur für einfache Vorg?nge geeignet sind. 7. Mit Standard ausw?hlen erm?glicht nicht blockierende Kanalvorg?nge, w?hrend Sie mit der Zeit ausw?hlen. Zusammen erm?glichen diese Primitiven robuste, effiziente gleichzeitige GO -Programme, die über grundlegende Goroutinen und Kan?le hinausgehen.
Wenn Sie an go
-Anweisungen und der grundlegenden Kanalnutzung vorbeigezogen sind, enthüllt Go's Concallelrency Toolkit tiefere, leistungsst?rkere Primitive. Diese Tools helfen Ihnen beim Schreiben eines sichereren und effizienteren gleichzeitigeren Code - insbesondere in komplexen Systemen, in denen Koordination, Stornierung und gemeinsame staatliche Angelegenheit. Lassen Sie uns die wichtigsten Parallelit?tsprimitiven jenseits der Grundlagen untersuchen.

1. sync.WaitGroup
- Koordination von Goroutine -Abschluss
W?hrend go
eine Goroutine startet, k?nnen Sie mit sync.WaitGroup
auf eine Sammlung von Goroutinen warten - ohne Kan?le.
Wann Sie es verwenden : Sie haben eine bekannte Anzahl von Goroutinen, die Arbeit erledigen, und Sie m?chten, dass die Haupt- (oder übergeordnete) Goroutine bis zum Ende blockiert.

var wg sync.waitgroup für i: = 0; i <5; ich { wg.add (1) Go func (id int) { aufschieben wg.done () fmt.printf ("Worker %d Done \ n", id) }(ich) } wg.wait () // Bl?cke, bis alle Done () aufgerufen werden
Schlüsselpunkte :
- Rufen Sie immer
Add(n)
bevor Sie Goroutinen starten. - Rufen Sie
Done()
überdefer
an, um sicherzustellen, dass es auch dann ausgeführt wird, wenn die Goroutine in Panik ger?t. - Nicht sicher, eine
WaitGroup
ohne ordnungsgem??e Synchronisation wiederzuverwenden.
2. sync.Mutex
und sync.RWMutex
- Schutz der gemeinsamen Daten schützen
Kan?le eignen sich hervorragend für die Eigentümerübertragung, aber manchmal müssen Sie gemeinsam gemeinsame Daten lesen oder schreiben.

var ( mu sync.mutex Data = make (map [string] int) ) Func Update (Schlüsselstring, Val int) { mu.lock () aufschieben mu.unlock () Daten [Schlüssel] = val } Func get (Schlüsselstring) int { mu.lock () aufschieben mu.unlock () Daten zurückgeben [Schlüssel] }
Besser mit RWMutex
, wenn die Lesevorg?nge h?ufig sind und selten schreibt:
mu.rlock () Defer mu.runlock () aufschieben Daten zurückgeben [Schlüssel]
-
RLock()
erlaubt mehreren Lesern. -
Lock()
ist für exklusive (Schreib-) Zugriff.
Tipp : Vermeiden Sie es, Schl?sser w?hrend der E/A- oder langen Operationen zu halten - zuerst Daten.
3. context.Context
- Stornierungs- und Fristverbreitung
Der context
ist die Standardmethode zur Signalisierung von Stornieren über Goroutinen hinweg, insbesondere in HTTP-Servern, RPCs oder langlebigen Aufgaben.
CTX, Cancel: = context.withTimeout (context.background (), 2*time.second) Aufhebung stornieren () go func () { time.sleep (3 * time.second) w?hlen { Fall <-ctx.done (): fmt.println ("storniert:", ctx.err ()) } } ())
Gemeinsame Muster :
- Verwenden Sie
context.WithCancel
,WithTimeout
oderWithDeadline
. - Pass
ctx
als erstes Argument für Funktionen. - überprüfen Sie
ctx.Done()
in Schleifen oder vor teuren Vorg?ngen. - Rufen Sie immer
cancel()
, um Lecks zu vermeiden.
Warum es wichtig ist : Es erm?glicht saubere, hierarchische Herunterfahren über Deep Call -Stapel.
4. sync.Once
- Sicherstellung einer einzelnen Initialisierung
Nützlich für die faule Initialisierung des globalen Zustands - EG, Konfiguration, Datenbankverbindungen.
var einmal synchronisieren var db *sql.db func getdb () *sql.db { einst.do (func () { db, _ = sql.open ("sqlite", "app.db") }) Return DB }
-
Do(f)
f
genau einmal, auch unter starker Parallelit?t. - Wenn mehrere Goroutines es nennen, wird nur einer
f
ausgeführt. Andere blockieren und warten.
HINWEIS : Wenn f
Panik in Panik berücksichtigt wird, ist es Once
ausgeführt - also kein Wiederholung.
5. sync.Pool
- Reduzierung des GC -Drucks mit der Wiederverwendung von Objekten
sync.Pool
richtungssübergreifend tempor?re Objekte zur Reduzierung der Allokation und der GC-Last-ideal für Hochleistungscode.
var bufferpool = sync.pool { Neu: func () Schnittstelle {} { Neue zurückgeben (Bytes.Buffer) }, } Func -Prozess (Daten [] byte) { buf: = bufferpool.get (). (*bytes.buffer) buf.reset () buf.write (Daten) // ... BUF verwenden Bufferpool.put (BUF) // zurück zum Pool zurückkehren }
Wichtig :
- Es werden keine Garantieobjekte wiederverwendet.
- Verlassen Sie sich nicht auf
Pool
, um Korrektheit - nur Leistung. - Vermeiden Sie es, gro?e oder unbegrenzte Gegenst?nde in Pools zu legen.
Am besten für : Puffer, JSON -Encoder, h?ufig zugewiesene Strukturen.
6. atomic
-Paket-lockfreie Vorg?nge bei Primitiven
Für einfache Operationen (z. B. Z?hler) vermeidet sync/atomic
Mutex -Overhead.
var counter int64 go func () { atomic.addint64 (& counter, 1) } ()) // sicher lesen Wert: = atomic.loadint64 (& counter)
Verfügbare Typen : int32
, int64
, uint32
, uint64
, uintptr
, unsafe.Pointer
.
Anwendungsf?lle :
- Performance -Z?hler.
- Flaggen (z. B.
atomic.Bool
überint32
). - Referenzz?hlung.
Achtung : Nur für einfache Operationen. Komplexe Logik ben?tigt noch Mutexes oder Kan?le.
7. select
mit default
und time.After
.
über den einfachen Empfang hinaus kann select
nicht blockierende oder zeitübergreifende Arbeiten erledigen.
Nicht blockierender Empfang :
w?hlen { Fall MSG: = <-ch: fmt.println ("empfangen:", msg) Standard: fmt.println ("Keine Nachricht verfügbar") }
Mit Auszeit :
w?hlen { Fall MSG: = <-ch: fmt.println ("Got:", msg) Fall <-Time.After (100 * Zeit.Millisekunde): fmt.println ("Timed Out") }
Tipp : time.After
Sie context.WithTimeout
.
Letzte Gedanken
Go's Concurrency -Modell geht weit über go
und chan
hinaus. Mit Bedacht verwendet:
-
WaitGroup
Fertigstellung. -
Mutex
schützt den gemeinsamen Zustand. -
Context
verwaltet Lebenszyklus und Stornierung. -
Once
,Pool
undatomic
optimieren die Leistung und Korrektheit.
Sie ben?tigen nicht alle in jedem Programm - aber zu wissen, wann Sie für jeden greifen müssen, macht Ihren gleichzeitigen Go -Code robuster und effizienter.
Sobald Sie die ?Hello -Welt“ von Goroutines hinter sich haben, k?nnen Sie diese Primitiven erstellen, wenn Sie echte Systeme erstellen k?nnen.
Das obige ist der detaillierte Inhalt vonGehen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Hei?e KI -Werkzeuge

Undress AI Tool
Ausziehbilder kostenlos

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

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

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





ToInteGrategolangServicesWithExistingPythoninFrastructure, benutzerdepisorgrpcforinter-serviceCommunication, erlaubtgoandhonAppStoInteractSeamlos-ThroughStandardizedProtocols.1.Userestapis (VICREFRAME-LIKEIGININGOANDOANDOSFLASHINGYTHON) ORGRPC

GolangoffersSuperiorperformance, NativeConcurrencyViagoroutines und efficienionResourceuse, MakingidealforHigh-Travaffic, niedrig-ladencyapis;

Golang wird haupts?chlich für die Back-End-Entwicklung verwendet, kann aber auch eine indirekte Rolle im Front-End-Bereich spielen. Die Konstruktionsziele konzentrieren sich auf leistungsstarke, gleichzeitige Programmierungen und Systeme auf Systemebene und eignen sich zum Erstellen von Back-End-Anwendungen wie API-Servern, Microservices, verteilten Systemen, Datenbankoperationen und CLI-Tools. Obwohl Golang nicht die Mainstream-Sprache für das Web-Front-End ist, kann er über Gopherjs in JavaScript zusammengestellt werden, auf WebAssembly über Tinygo ausgeführt werden oder HTML-Seiten mit einer Vorlagenmotor zur Teilnahme an der Front-End-Entwicklung erzeugen. Die moderne Front-End-Entwicklung muss jedoch noch auf JavaScript/Typecript und sein ?kosystem beruhen. Daher eignet sich Golang besser für die Auswahl der Technologiestapel mit Hochleistungs-Backend als Kern.

Der Schlüssel zur Installation von GO besteht darin, die richtige Version auszuw?hlen, Umgebungsvariablen zu konfigurieren und die Installation zu überprüfen. 1. Gehen Sie zur offiziellen Website, um das Installationspaket des entsprechenden Systems herunterzuladen. Windows verwendet .msi -Dateien, macOS. PKG -Dateien, Linux verwendet .tar.gz -Dateien und entpackt sie in /usr /lokales Verzeichnis. 2. Konfigurieren Sie Umgebungsvariablen, bearbeiten Sie ~/.bashrc oder ~/.zshrc in Linux/macOS, um Pfad und GOPath hinzuzufügen, und Windows -Set -Pfad, um die Systemeigenschaften zu verfolgen. 3.. Verwenden Sie das Regierungsbefehl, um die Installation zu überprüfen, und führen Sie das Testprogramm Hello.go aus, um zu best?tigen, dass die Zusammenstellung und Ausführung normal ist. Pfadeinstellungen und Schleifen w?hrend des gesamten Prozesses

Golang verbraucht normalerweise weniger CPU und Speicher als Python beim Erstellen von Webdiensten. 1. Golangs Goroutine -Modell ist effizient bei der Planung, verfügt über eine starke Funktionsverarbeitungsfunktionen und eine geringere CPU -Nutzung. 2. GO wird in nativen Code kompiliert, beruht w?hrend der Laufzeit nicht auf virtuelle Maschinen und hat eine geringere Speicherverwendung. 3. Python hat aufgrund des GIL- und Interpretationsausführungsmechanismus eine gr??ere CPU- und Ged?chtnisaufwand in gleichzeitigen Szenarien; 4. Obwohl Python eine hohe Entwicklungseffizienz und ein reichhaltiges ?kosystem aufweist, verbraucht es eine hohe Ressource, die für Szenarien mit geringen Parallelit?tsanforderungen geeignet ist.

Um ein GraphQLAPI in Go zu erstellen, wird empfohlen, die GQLGen -Bibliothek zur Verbesserung der Entwicklungseffizienz zu verwenden. 1. W?hlen Sie zun?chst die entsprechende Bibliothek wie GQLGen aus, die die automatische Codegenerierung basierend auf dem Schema unterstützt. 2. Definieren Sie dann GraphQlSchema, beschreiben Sie das API -Struktur und das Abfrageportal, z. B. das Definieren von Post -Typen und Abfragemethoden; 3. Initialisieren Sie dann das Projekt und generieren Sie grundlegende Code, um die Gesch?ftslogik in Resolver zu implementieren. 4. Schlie?lich verbinden Sie GraphQlHandler mit HTTPServer und testen Sie die API über den integrierten Spielplatz. Zu den Anmerkungen geh?ren Feldnamenspezifikationen, Fehlerbehandlung, Leistungsoptimierung und Sicherheitseinstellungen, um die Projektwartung sicherzustellen

Die Auswahl des MicroService -Frameworks sollte auf der Grundlage der Projektanforderungen, der Teamtechnologie -Stack und der Leistungserwartungen ermittelt werden. 1. Angesichts der leistungsstarken Anforderungen ist Kitex oder Gomicro von GO Priorit?t, insbesondere Kitex eignet sich für komplexe Service-Governance und gro? angelegte Systeme. 2. Fastapi oder Flask of Python ist flexibler in schnellen Entwicklungs- und Iterationsszenarien, geeignet für kleine Teams und MVP -Projekte. 3. Die F?higkeiten des Teams wirken sich direkt auf die Auswahlkosten aus, und wenn bereits eine GO -Ansammlung vorliegt, wird es weiterhin effizienter sein. Die Ausschlagkonvertierung des Python -Teams kann die Effizienz beeintr?chtigen. V. 5. Eine hybride Architektur kann nach dem Modul übernommen werden, ohne sich an eine einzelne Sprache oder einen einzelnen Framework halten zu müssen.

Sync.waitGroup wird verwendet, um auf eine Gruppe von Goroutinen zu warten, um die Aufgabe zu erledigen. Sein Kern besteht darin, drei Methoden zusammenzuarbeiten: hinzufügen, fertig und warten. 1.Add (n) Stellen Sie die Anzahl der Goroutiner fest, um zu warten; 2.Done () wird am Ende jeder Goroutine bezeichnet, und die Anzahl wird um eins reduziert; 3.wait () blockiert die Hauptkorutine, bis alle Aufgaben erledigt sind. Beachten Sie bitte, dass Sie bei der Verwendung au?erhalb der Goroutine doppelte Warten vermeiden, und stellen Sie sicher, dass der Don aufgerufen wird. Es wird empfohlen, es mit Aufhebung zu verwenden. Es ist h?ufig bei der gleichzeitigen Krabbeln von Webseiten, der Stapeldatenverarbeitung und anderer Szenarien und kann den Parallelit?tsprozess effektiv steuern.
