Heim Backend-Entwicklung Golang Schnellstart zur Netzwerkprogrammierung: Gleichzeitige Programmierung in der Go-Sprache

Schnellstart zur Netzwerkprogrammierung: Gleichzeitige Programmierung in der Go-Sprache

Jun 18, 2023 am 10:01 AM
go语言 并发编程 网络编程

Schnellstart zur Netzwerkprogrammierung: Gleichzeitige Programmierung in der Go-Sprache

Mit der Entwicklung des Internets ist die Netzwerkprogrammierung nach und nach zu einer der Fähigkeiten geworden, die Programmierer beherrschen müssen. Die gleichzeitige Programmierung ist ein unverzichtbarer Bestandteil der Netzwerkprogrammierung, insbesondere in Situationen mit hoher Parallelität. Die Go-Sprache ist eine Programmiersprache, die sich durch effizientes gleichzeitiges Programmieren auszeichnet und deren Parallelitätsmodell einfacher und klarer ist als das anderer Sprachen. In diesem Artikel wird die gleichzeitige Programmierung in der Go-Sprache vorgestellt, um Anfängern den schnellen Einstieg zu erleichtern.

  1. Goroutine

Goroutine ist ein leichter Thread in der Go-Sprache. Parallelität in der Go-Sprache wird durch Goroutine implementiert. Jede Goroutine kann verschiedene Codes gleichzeitig ausführen, und der Overhead von Goroutine ist sehr gering. Zehntausende Goroutinen können problemlos geöffnet werden, ohne sich Gedanken über den Speicherverbrauch machen zu müssen. Die grundlegende Verwendung von Goroutine ist sehr einfach. Fügen Sie einfach das Schlüsselwort go vor dem Funktionsaufruf hinzu, um eine Goroutine zu starten.

Zum Beispiel können wir eine Goroutine mit dem folgenden Code erstellen:

func main() {
    go printHello()
}

func printHello() {
    fmt.Println("Hello, world!")
}
Nach dem Login kopieren

Wenn im obigen Code das Go-Programm „go printHello()“ ausführt, startet es eine neue Goroutine, um die Funktion „printHello“ auszuführen. Da die printHello-Funktion unabhängig von der Hauptfunktion ausgeführt wird, gibt das Programm sofort „Hello, world!“ aus.

  1. Channel

Die Kommunikation zwischen Goroutinen erfolgt über Channel. Der Kanal kann als Pipeline zwischen Goroutinen betrachtet werden und zum Senden und Empfangen von Daten verwendet werden. Der Kanal in der Go-Sprache kann Daten synchron übertragen und kann auch zur Implementierung asynchroner Programmierung verwendet werden. Die Erstellung und Verwendung eines Kanals ist ebenfalls sehr einfach. Verwenden Sie einfach die Make-Funktion, um ihn zu erstellen, und verwenden Sie dann den <-Operator, um Daten zu senden und zu empfangen.

Zum Beispiel können wir einen Kanal erstellen und Daten über den folgenden Code übertragen:

func main() {
    ch := make(chan int)
    go send(ch)
    fmt.Println(<-ch)
}

func send(ch chan int) {
    ch <- 1
}
Nach dem Login kopieren

Im obigen Code erstellen wir einen ganzzahligen Kanal und starten eine Goroutine für die Datenübertragung. Die Hauptfunktion blockiert und wartet darauf, dass der Kanal Daten über die Anweisung <-ch überträgt. Nach dem Empfang der Daten gibt das Programm „1“ aus.

Channel kann zum Übertragen von Daten zwischen mehreren Goroutinen verwendet werden, wodurch Synchronisierungsprobleme vermieden werden, die bei der Verwendung von Shared Memory berücksichtigt werden müssen. Darüber hinaus kann über Channel die Koordination und Synchronisation zwischen mehreren Goroutinen erreicht werden, wodurch komplexe gleichzeitige Programmieraufgaben realisiert werden können.

  1. Select

Beim Lesen von Daten aus mehreren Kanälen in mehreren Goroutinen können Sie zur Verarbeitung die Select-Syntax in der Go-Sprache verwenden. Die Select-Syntax ähnelt der Switch-Syntax. Sie kann die Dateninteraktion mehrerer Kanäle überwachen. Wenn Daten in einem der Kanäle angezeigt werden, wird der entsprechende Codeblock ausgelöst.

Zum Beispiel können wir mit dem folgenden Code zwei Goroutinen erstellen und die Select-Syntax verwenden, um das Chanenl-Lesen zu verarbeiten:

func main() {
    ch1 := make(chan int)
    ch2 := make(chan int)
    go func() {
        ch1 <- 1
    }()
    go func() {
        ch2 <- 2
    }()
    select {
        case x := <- ch1:
            fmt.Println("Received from ch1:", x)
        case x := <- ch2:
            fmt.Println("Received from ch2:", x)
    }
}
Nach dem Login kopieren

Im obigen Code erstellen wir zwei Goroutinen, um Daten jeweils an zwei Kanäle zu senden. Verwenden Sie die Select-Anweisung, um die Datenübertragung der beiden Kanäle zu überwachen. Solange einer der Kanäle Daten sendet, wird der entsprechende Codeblock ausgeführt und die empfangenen Daten ausgegeben.

  1. Mutex

Die Go-Sprache unterstützt den gleichzeitigen Zugriff mehrerer Threads auf dieselbe Variable. Um das Problem der Dateninkonsistenz beim gleichzeitigen Schreiben einer Variablen zu lösen, stellt die Go-Sprache Mutex-Mutex zum Sperren bereit. Wenn wir die Variable ändern, öffnen wir die Sperre zunächst über die Mutex.Lock()-Methode. Zu diesem Zeitpunkt erhält nur ein Thread die Sperre, und andere Threads werden zu diesem Zeitpunkt blockiert, wenn sie versuchen, die Sperre zu erhalten Nachdem wir die Variable verwendet haben, müssen wir sie manuell mit der Mutex.Unlock()-Methode entsperren, um die Sperrressource freizugeben.

Zum Beispiel können wir die Verwendung von Mutex durch den folgenden Code demonstrieren:

import (
    "fmt"
    "sync"
    "time"
)

var wg sync.WaitGroup
var mutex sync.Mutex
var counter int

func main() {
  for i := 0; i < 10; i++ {
    wg.Add(1)
    go increment()
  }
  wg.Wait()
  fmt.Println("Final counter:", counter)
}

func increment() {
  mutex.Lock()
  defer mutex.Unlock()
  counter++
  time.Sleep(time.Second)
  fmt.Println("Counter value:", counter)
  wg.Done()
}
Nach dem Login kopieren

Im obigen Code erstellen wir 10 Goroutinen und jede Goroutine fügt eine zur Zählervariablen hinzu. Um die Datengenauigkeit sicherzustellen, verwenden wir Mutex zum Schutz des Zählers. Rufen Sie die Mutex.Lock()-Methode in Goroutine auf, um die Sperre zu erhalten, und rufen Sie dann die Mutex.Unlock()-Methode auf, um sie nach dem Vorgang zu entsperren. Nachdem Sie WaitGroup verwendet haben, um auf den Abschluss aller Goroutine-Ausführungen zu warten, geben Sie den endgültigen Zählerwert aus.

Zusammenfassung

Die gleichzeitige Programmierung in der Go-Sprache verwendet Goroutine und Channel für die Datenübertragung, Synchronisierung und den Schutz von Variablen durch Mutex sowie das Lesen mehrerer Kanäle durch Select. Durch die rationale Nutzung dieser Mechanismen können wir effiziente, klare und leicht zu wartende gleichzeitige Programme schreiben, die in Anwendungsszenarien mit hoher Parallelität eine wichtige Rolle spielen.

Das obige ist der detaillierte Inhalt vonSchnellstart zur Netzwerkprogrammierung: Gleichzeitige Programmierung 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

Video Face Swap

Video Face Swap

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

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)

Wie konvertieren Sie XML in Ihr Telefon in PDF? Wie konvertieren Sie XML in Ihr Telefon in PDF? Apr 02, 2025 pm 10:18 PM

Es ist nicht einfach, XML direkt auf Ihr Telefon in PDF umzuwandeln, kann jedoch mit Hilfe von Cloud -Diensten erreicht werden. Es wird empfohlen, eine leichte mobile App zu verwenden, um XML -Dateien hochzuladen und generierte PDFs zu empfangen und sie mit Cloud -APIs zu konvertieren. Cloud -APIs verwenden serverlose Computerdienste, und die Auswahl der richtigen Plattform ist entscheidend. Bei der Behandlung von XML -Parsen und PDF -Generation müssen Komplexität, Fehlerbehebung, Sicherheit und Optimierungsstrategien berücksichtigt werden. Der gesamte Prozess erfordert, dass die Front-End-App und die Back-End-API zusammenarbeiten, und es erfordert ein gewisses Verständnis einer Vielzahl von Technologien.

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

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

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

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

See all articles