Maison > développement back-end > Golang > le corps du texte

Aller au guide de programmation simultanée du langage

王林
Libérer: 2024-03-27 18:30:05
original
407 Les gens l'ont consulté

Aller au guide de programmation simultanée du langage

Go est un langage de programmation open source conçu pour créer des logiciels simples, fiables et efficaces. L'une des fonctionnalités les plus remarquables est ses puissantes capacités de programmation simultanée. Grâce aux fonctionnalités de concurrence du langage Go, les processeurs multicœurs peuvent être mieux utilisés pour obtenir un traitement parallèle efficace et améliorer les performances et la vitesse des programmes.

En langage Go, la mise en œuvre de la programmation concurrente repose principalement sur la goroutine et le canal. Goroutine est un thread léger dans le langage Go qui permet de créer et de gérer facilement un grand nombre de tâches simultanées. Le canal est un pipeline utilisé pour la communication et le transfert de données entre les goroutines.

Ce qui suit utilisera quelques exemples de code spécifiques pour montrer comment utiliser goroutine et canal pour implémenter la programmation simultanée en langage Go.

1. Utilisez goroutine pour créer des tâches simultanées

package main

import (
    "fmt"
    "time"
)

func task(id int) {
    for i := 0; i < 5; i++ {
        fmt.Printf("Task %d: %d
", id, i)
        time.Sleep(time.Second)
    }
}

func main() {
    for i := 0; i < 3; i++ {
        go task(i)
    }
    time.Sleep(6 * time.Second) // 等待所有goroutine执行完毕
}
Copier après la connexion

Dans le code ci-dessus, 3 goroutines sont créées via l'instruction go task(i) pour exécuter la fonction task à en même temps. Chaque goroutine affichera l'état d'exécution de 5 tâches et attendra que toutes les goroutines terminent leur exécution via time.Sleep. go task(i)语句创建了3个goroutine来同时执行task函数,每个goroutine都会输出5次任务的执行情况,通过time.Sleep来等待所有goroutine执行完毕。

2. 使用channel进行数据交互

package main

import "fmt"

func producer(ch chan int) {
    for i := 0; i < 5; i++ {
        ch <- i
    }
    close(ch) // 关闭channel
}

func consumer(ch chan int) {
    for {
        val, ok := <-ch
        if !ok {
            break
        }
        fmt.Printf("Received: %d
", val)
    }
}

func main() {
    ch := make(chan int)
    go producer(ch)
    go consumer(ch)
    select {} // 阻塞主goroutine
}
Copier après la connexion

在上面的代码中,通过producer函数向channel发送数据,通过consumer函数从channel接收数据,通过close(ch)来关闭channel。通过select {}

2. Utilisez les canaux pour l'interaction des données

rrreee

Dans le code ci-dessus, les données sont envoyées au canal via la fonction producteur, les données sont reçues du canal via le consommateur, et les données sont reçues du canal via la fonction <code>producteur code>close(ch) pour fermer le canal. Utilisez l'instruction select {} pour bloquer la goroutine principale afin que le programme puisse continuer à s'exécuter jusqu'à ce que toutes les tâches soient terminées. 🎜🎜Grâce aux exemples de code simples ci-dessus, vous pouvez voir que le langage Go fournit un puissant support de programmation simultanée via goroutine et canal, et peut facilement implémenter l'exécution parallèle de tâches simultanées, la transmission de données et la communication. Pour les développeurs qui souhaitent en savoir plus sur la programmation simultanée, maîtriser les compétences de programmation simultanée du langage Go sera un bon moyen d'améliorer leurs compétences et d'apprendre. 🎜

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal
À propos de nous Clause de non-responsabilité Sitemap
Site Web PHP chinois:Formation PHP en ligne sur le bien-être public,Aidez les apprenants PHP à grandir rapidement!