Inhaltsverzeichnis
Mutex und RWMutex
WaitGroup
Cond
Einmal
Fazit
Heim Backend-Entwicklung Golang Wie implementiert man Parallelitätssicherheit in der Go-Sprache?

Wie implementiert man Parallelitätssicherheit in der Go-Sprache?

Jun 10, 2023 am 08:13 AM
go语言 实现 并发安全

Mit der kontinuierlichen Weiterentwicklung der Computertechnologie müssen wir für die Programmverarbeitung von Single-Thread zu Multi-Thread übergehen. Im Vergleich zum herkömmlichen Parallelitätsverarbeitungsmodell hat der leistungsstarke Parallelitätsverarbeitungsmechanismus der Go-Sprache die Aufmerksamkeit vieler Entwickler auf sich gezogen. Die Go-Sprache bietet einen einfachen Implementierungsmechanismus, der das Schreiben von authentischem gleichzeitigem Code erleichtert.

Es ist jedoch unvermeidlich, dass eine Multithread-Umgebung viele Rennbedingungen mit sich bringt. Wenn mehrere Threads gleichzeitig versuchen, dieselbe gemeinsam genutzte Ressource zu lesen und zu schreiben, kann es aufgrund der Unsicherheit der Ausführungsreihenfolge zu unerwarteten Ergebnissen kommen. Race Condition ist eines der potenziellen Probleme, die Entwickler am meisten fürchten.

Um potenzielle Probleme bei der gleichzeitigen Verarbeitung zu vermeiden, bietet die Go-Sprache eine große Auswahl an Standardbibliotheken: sync. In diesem Artikel wird der Mechanismus zum Erreichen der Parallelitätssicherheit durch die Synchronisierungsbibliothek vorgestellt.

Mutex und RWMutex

Mutex sind die am häufigsten verwendeten Mechanismen. Zu jedem Zeitpunkt kann nur eine Coroutine das Mutex-Objekt abrufen, und andere Coroutinen müssen warten, bis die vorherige Coroutine die Sperre aufhebt, bevor sie mit der Ausführung fortfahren können. Mutex kann zum Schutz gemeinsam genutzter Ressourcen verwendet werden, sodass Code sicher und stabil ausgeführt werden kann.

RWMutex ist ein weiterer Mutex-Sperrtyp, der der Erweiterung von Mutex im Bereich Lesen und Schreiben entspricht. RWMutex enthält zwei Zähler: Lesezähler und Schreibzähler.

  • Wenn die Lese-Coroutine noch einen Lesevorgang ausführt, wird der Schreibvorgang gesperrt und wartet auf das Ende des Lesevorgangs.
  • Wenn die schreibende Coroutine den Sperrvorgang aufruft, werden alle laufenden Lese- und Schreibvorgänge der Coroutine gesperrt.

Dieser Mechanismus stellt sicher, dass mehrere Coroutinen gleichzeitig Lesevorgänge ausführen können und nur eine einzige Coroutine Schreibvorgänge ausführen kann.

var rwMutex sync.RWMutex
var count int
func read() {
    rwMutex.RLock()
    defer rwMutex.RUnlock()

    fmt.Println(count)
}

func write() {
    rwMutex.Lock()
    defer rwMutex.Unlock()

    count++
}
Nach dem Login kopieren

Im obigen Beispielcode haben wir eine Sperre vom Typ RWMutex verwendet, um die Lese- und Schreibvorgänge der Zählvariablen zu schützen. Wenn ein Thread die Funktion write() aufruft, wird der Schreibzähler gesperrt und alle anderen Coroutinen werden am Lesen und Schreiben gehindert. Wenn ein Thread die Funktion read() aufruft, wird der Lesezähler gesperrt und andere Coroutinen dürfen Lesevorgänge ausführen.

WaitGroup

WaitGroup wird verwendet, um darauf zu warten, dass eine Gruppe von Coroutinen die Ausführung abschließt. Angenommen, wir haben n Coroutinen, die ausgeführt werden müssen, dann müssen wir in der Hauptcoroutine waitGroup.Add(n) aufrufen. WaitGroup.Done() wird aufgerufen, nachdem jede Coroutine die Ausführung abgeschlossen hat.

func main() {
    var wg sync.WaitGroup

    for i := 0; i < 5; i++ {
        wg.Add(1)
        go func(n int) {
            fmt.Println("goroutine ", n)
            wg.Done()
        }(i)
    }
    wg.Wait()
}
Nach dem Login kopieren

In diesem Beispiel verwenden wir WaitGroup, um auf die Ausführung jeder Goroutine zu warten und schließlich auf den Abschluss aller Goroutinen zu warten, bevor wir den Hauptausführungsprozess beenden.

Cond

Wenn mehrere Coroutinen anhalten oder bestimmte Vorgänge ausführen müssen, können wir Cond verwenden. Es ist üblich, Cond in Verbindung mit Locks und WaitGroup zu verwenden. Es ermöglicht Goroutinen, gleichzeitig zu blockieren, bis sich eine Bedingungsvariable ändert.

var cond = sync.NewCond(&sync.RWMutex{})

func printOddNumbers() {
    for i := 0; i < 10; i++ {
        cond.L.Lock()
        if i%2 == 1 {
            fmt.Println(i)
            cond.Signal()
        } else {
            cond.Wait()
        }
        cond.L.Unlock()
    }
}

func printEvenNumbers() {
    for i := 0; i < 10; i++ {
        cond.L.Lock()
        if i%2 == 0 {
            fmt.Println(i)
            cond.Signal()
        } else {
            cond.Wait()
        }
        cond.L.Unlock()
    }
}
Nach dem Login kopieren

Im obigen Codebeispiel haben wir Cond verwendet, um sicherzustellen, dass gerade Zahlen und ungerade Zahlen getrennt ausgegeben werden. Jede Coroutine verwendet sync.Mutex, um die Goroutine zu sperren und darauf zu warten, dass eine andere Coroutine zuerst auf die gemeinsam genutzte Variable zugreift und dann den Wert der Variablen überwacht.

Einmal

In einigen Fällen müssen Sie sicherstellen, dass bestimmte Vorgänge nur einmal ausgeführt werden, z. B. das einmalige Lesen der Konfigurationsdatei oder das einmalige Initialisieren des globalen Status. Zu diesem Zweck wurde der sync.Once-Typ der Go-Sprache geboren. Wenn die Funktion zum ersten Mal aufgerufen wird, führt sie den darin enthaltenen Code aus und wird nach nachfolgenden Aufrufen nicht erneut ausgeführt.

var once sync.Once

func doSomething() {
    once.Do(func() {
        fmt.Println("Do something")
    })
}
Nach dem Login kopieren

Im obigen Beispiel haben wir sync.Once verwendet, um die doSomething-Funktion sicher auszuführen. Beim ersten Aufruf von doSomething wird die Funktion nur einmal mit Once.Do() ausgeführt.

Fazit

In diesem Artikel stellen wir die in der Go-Sprache häufig verwendeten Sperren und Mechanismen vor, um die Sicherheit von gleichzeitigem Code zu gewährleisten. Die Typen Mutex, RWMutex, WaitGroup, Cond und Once, die die Sync-Bibliothek verwenden, sind alle sehr leistungsfähig und können zum Entwerfen sicherer und effizienter gleichzeitiger Programme verwendet werden. Da sich Parallelitätsmechanismen ständig weiterentwickeln, ist es wichtig, die neuesten Fortschritte in der Parallelprogrammierung zu verstehen, um Ihre Entwicklungskompetenzen wettbewerbsfähig zu halten.

Das obige ist der detaillierte Inhalt vonWie implementiert man Parallelitätssicherheit in der Go-Sprache?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
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

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌
Will R.E.P.O. Crossplay haben?
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Welche Bibliotheken werden für die Operationen der schwimmenden Punktzahl in Go verwendet? Welche Bibliotheken werden für die Operationen der schwimmenden Punktzahl in Go verwendet? Apr 02, 2025 pm 02:06 PM

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

Was ist das Problem mit Warteschlangen -Thread in Go's Crawler Colly? Was ist das Problem mit Warteschlangen -Thread in Go's Crawler Colly? Apr 02, 2025 pm 02:09 PM

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. � ...

Warum hat das Drucken von Saiten mit Println und String () -Funktionen unterschiedliche Effekte? Warum hat das Drucken von Saiten mit Println und String () -Funktionen unterschiedliche Effekte? Apr 02, 2025 pm 02:03 PM

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

Wie löste ich das Problem des Typs des user_id -Typs bei der Verwendung von Redis -Stream, um Nachrichtenwarteschlangen in GO -Sprache zu implementieren? Wie löste ich das Problem des Typs des user_id -Typs bei der Verwendung von Redis -Stream, um Nachrichtenwarteschlangen in GO -Sprache zu implementieren? Apr 02, 2025 pm 04:54 PM

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

Was soll ich tun, wenn die benutzerdefinierten Strukturbezeichnungen in Goland nicht angezeigt werden? Was soll ich tun, wenn die benutzerdefinierten Strukturbezeichnungen in Goland nicht angezeigt werden? Apr 02, 2025 pm 05:09 PM

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 ...

Welche Bibliotheken in GO werden von großen Unternehmen entwickelt oder von bekannten Open-Source-Projekten bereitgestellt? Welche Bibliotheken in GO werden von großen Unternehmen entwickelt oder von bekannten Open-Source-Projekten bereitgestellt? Apr 02, 2025 pm 04:12 PM

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 ist der Unterschied zwischen 'var' und 'Typ' Typenwort Definition in der GO -Sprache? Was ist der Unterschied zwischen 'var' und 'Typ' Typenwort Definition in der GO -Sprache? Apr 02, 2025 pm 12:57 PM

Zwei Möglichkeiten, Strukturen in der GO -Sprache zu definieren: Der Unterschied zwischen VAR- und Typ -Schlüsselwörtern. Bei der Definition von Strukturen sieht die Sprache oft zwei verschiedene Schreibweisen: Erstens ...

Warum gibt es bei Verwendung von SQL.Open keinen Fehler an, wenn DSN leer ist? Warum gibt es bei Verwendung von SQL.Open keinen Fehler an, wenn DSN leer ist? Apr 02, 2025 pm 12:54 PM

Warum meldet der DSN bei Verwendung von SQL.Open keinen Fehler? In Go Language, Sql.open ...

See all articles