


Compétences en programmation simultanée : utilisation avancée de Go WaitGroup
Conseils de programmation simultanée : utilisation avancée de Go WaitGroup
Dans la programmation simultanée, coordonner et gérer l'exécution de plusieurs tâches simultanées est une tâche importante. Le langage Go fournit une primitive de concurrence très pratique - WaitGroup, qui peut nous aider à implémenter le contrôle de concurrence avec élégance. Cet article présentera l'utilisation de base de WaitGroup et se concentrera sur son utilisation avancée, en utilisant des exemples de code spécifiques pour aider les lecteurs à mieux le comprendre et l'appliquer.
WaitGroup est une primitive de concurrence intégrée au langage Go, qui peut nous aider à attendre la fin de tâches simultanées. Il propose trois méthodes : Ajouter, Terminer et Attendre. La méthode Add est utilisée pour définir le nombre de tâches en attente, la méthode Done est utilisée pour réduire le nombre de tâches en attente et la méthode Wait est utilisée pour bloquer la coroutine actuelle jusqu'à ce que toutes les tâches en attente soient terminées.
Voici un exemple simple montrant l'utilisation de base de WaitGroup :
package main import ( "fmt" "sync" "time" ) func main() { var wg sync.WaitGroup for i := 0; i < 5; i++ { wg.Add(1) go func(num int) { defer wg.Done() time.Sleep(time.Second) fmt.Println("Task", num, "done") }(i) } wg.Wait() fmt.Println("All tasks done") }
Dans le code ci-dessus, nous créons un objet WaitGroup wg et créons 5 tâches simultanées via une boucle. Lors de l'exécution de chaque tâche, nous utilisons la méthode Add pour augmenter le nombre de tâches en attente, et à la fin de la tâche, nous utilisons la méthode Done pour réduire le nombre de tâches en attente. Enfin, nous appelons la méthode Wait pour bloquer la coroutine principale jusqu'à ce que toutes les tâches en attente soient terminées.
En plus de l'utilisation de base, WaitGroup propose également une utilisation avancée, qui permet de contrôler l'exécution de tâches simultanées de manière plus flexible. Ci-dessous, nous présenterons en détail plusieurs utilisations avancées couramment utilisées.
- Exécuter un ensemble de tâches et définir le nombre maximum de simultanéités
Si nous devons exécuter un ensemble de tâches en même temps, mais que nous voulons limiter le nombre maximum de simultanéités, nous pouvons utiliser un canal tampon combiné avec WaitGroup pour y parvenir. Le code ci-dessous montre comment exécuter un ensemble de tâches en même temps, mais n'autorise qu'un maximum de 3 tâches à s'exécuter simultanément :
package main import ( "fmt" "sync" "time" ) func main() { var wg sync.WaitGroup maxConcurrency := 3 tasks := []int{1, 2, 3, 4, 5, 6, 7, 8, 9, 10} sem := make(chan struct{}, maxConcurrency) for _, task := range tasks { wg.Add(1) sem <- struct{}{} // 获取令牌,控制最大并发数 go func(num int) { defer wg.Done() time.Sleep(time.Second) fmt.Println("Task", num, "done") <-sem // 释放令牌,允许新的任务执行 }(task) } wg.Wait() fmt.Println("All tasks done") }
Dans le code ci-dessus, nous créons un canal sem tamponné et définissons sa taille au nombre maximum. des concurrences. Avant le début de chaque tâche, nous obtenons un jeton via l'instruction sem
- Timeout contrôle l'exécution des tâches simultanées
Parfois, nous souhaitons contrôler le temps d'exécution des tâches simultanées et mettre fin à l'exécution de la tâche lorsqu'elle expire. En utilisant des canaux tamponnés et des minuteries, nous pouvons facilement implémenter cette fonctionnalité. Le code suivant montre comment définir le délai d'expiration d'une tâche simultanée à 3 secondes :
package main import ( "fmt" "sync" "time" ) func main() { var wg sync.WaitGroup tasks := []int{1, 2, 3, 4, 5, 6, 7} timeout := 3 * time.Second done := make(chan struct{}) for _, task := range tasks { wg.Add(1) go func(num int) { defer wg.Done() // 模拟任务执行时间不定 time.Sleep(time.Duration(num) * time.Second) fmt.Println("Task", num, "done") // 判断任务是否超时 select { case <-done: // 任务在超时前完成,正常退出 return default: // 任务超时,向通道发送信号 close(done) } }(task) } wg.Wait() fmt.Println("All tasks done") }
Dans le code ci-dessus, nous créons un canal terminé et déterminons si le canal est fermé pendant l'exécution de la tâche pour déterminer si la tâche expire. Lorsqu'une tâche est terminée, nous utilisons l'instruction close(done) pour envoyer un signal au canal terminé pour indiquer que la tâche a expiré. Choisissez différentes branches via des instructions select pour gérer différentes situations.
Grâce à l'exemple de code ci-dessus, nous pouvons voir que l'utilisation avancée de WaitGroup est très pratique dans la programmation simultanée réelle. En maîtrisant ces techniques, nous pouvons mieux contrôler l'exécution des tâches concurrentes et améliorer les performances et la maintenabilité du code. J'espère que les lecteurs pourront avoir une compréhension approfondie de l'utilisation de WaitGroup grâce à l'introduction et à l'exemple de code de cet article, puis l'appliquer à des projets réels.
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!

GolangisidealforBuildingsCalableSystemsDuetoitSefficiency and Concurrency, tandis que les Implicites de l'Indrecosystem et le Golang'sDesignenCourageSlecElNCORES

Golang est meilleur que C en concurrence, tandis que C est meilleur que Golang en vitesse brute. 1) Golang obtient une concurrence efficace par le goroutine et le canal, ce qui convient à la gestion d'un grand nombre de tâches simultanées. 2) C Grâce à l'optimisation du compilateur et à la bibliothèque standard, il offre des performances élevées près du matériel, adaptées aux applications qui nécessitent une optimisation extrême.

Les raisons du choix de Golang comprennent: 1) des performances de concurrence élevées, 2) un système de type statique, 3) un mécanisme de collecte des ordures, 4) des bibliothèques et des écosystèmes standard riches, ce qui en fait un choix idéal pour développer des logiciels efficaces et fiables.

Golang convient au développement rapide et aux scénarios simultanés, et C convient aux scénarios où des performances extrêmes et un contrôle de bas niveau sont nécessaires. 1) Golang améliore les performances grâce à des mécanismes de collecte et de concurrence des ordures, et convient au développement de services Web à haute concurrence. 2) C réalise les performances ultimes grâce à la gestion manuelle de la mémoire et à l'optimisation du compilateur, et convient au développement du système intégré.

Golang fonctionne mieux en temps de compilation et en traitement simultané, tandis que C présente plus d'avantages dans la vitesse d'exécution et la gestion de la mémoire. 1.Golang a une vitesse de compilation rapide et convient pour un développement rapide. 2.C fonctionne rapidement et convient aux applications critiques. 3. Golang est simple et efficace dans le traitement simultané, adapté à la programmation simultanée. 4.C La gestion de la mémoire manuelle offre des performances plus élevées, mais augmente la complexité du développement.

L'application de Golang dans les services Web et la programmation système se reflète principalement dans sa simplicité, son efficacité et sa concurrence. 1) Dans les services Web, Golang prend en charge la création d'applications Web et d'API à haute performance via des bibliothèques HTTP puissantes et des capacités de traitement simultanées. 2) Dans la programmation système, Golang utilise des fonctionnalités proches du matériel et de la compatibilité avec le langage C pour être adapté au développement du système d'exploitation et aux systèmes intégrés.

Golang et C ont leurs propres avantages et inconvénients dans la comparaison des performances: 1. Golang convient à une concurrence élevée et à un développement rapide, mais la collecte des ordures peut affecter les performances; 2.C fournit des performances plus élevées et un contrôle matériel, mais a une complexité de développement élevée. Lorsque vous faites un choix, vous devez considérer les exigences du projet et les compétences en équipe de manière complète.

Golang convient aux scénarios de programmation haute performance et simultanés, tandis que Python convient au développement rapide et au traitement des données. 1.Golang met l'accent sur la simplicité et l'efficacité, et convient aux services back-end et aux microservices. 2. Python est connu pour sa syntaxe concise et ses bibliothèques riches, adaptées à la science des données et à l'apprentissage automatique.


Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

Video Face Swap
Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Article chaud

Outils chauds

MantisBT
Mantis est un outil Web de suivi des défauts facile à déployer, conçu pour faciliter le suivi des défauts des produits. Cela nécessite PHP, MySQL et un serveur Web. Découvrez nos services de démonstration et d'hébergement.

mPDF
mPDF est une bibliothèque PHP qui peut générer des fichiers PDF à partir de HTML encodé en UTF-8. L'auteur original, Ian Back, a écrit mPDF pour générer des fichiers PDF « à la volée » depuis son site Web et gérer différentes langues. Il est plus lent et produit des fichiers plus volumineux lors de l'utilisation de polices Unicode que les scripts originaux comme HTML2FPDF, mais prend en charge les styles CSS, etc. et présente de nombreuses améliorations. Prend en charge presque toutes les langues, y compris RTL (arabe et hébreu) et CJK (chinois, japonais et coréen). Prend en charge les éléments imbriqués au niveau du bloc (tels que P, DIV),

Dreamweaver CS6
Outils de développement Web visuel

DVWA
Damn Vulnerable Web App (DVWA) est une application Web PHP/MySQL très vulnérable. Ses principaux objectifs sont d'aider les professionnels de la sécurité à tester leurs compétences et leurs outils dans un environnement juridique, d'aider les développeurs Web à mieux comprendre le processus de sécurisation des applications Web et d'aider les enseignants/étudiants à enseigner/apprendre dans un environnement de classe. Application Web sécurité. L'objectif de DVWA est de mettre en pratique certaines des vulnérabilités Web les plus courantes via une interface simple et directe, avec différents degrés de difficulté. Veuillez noter que ce logiciel

ZendStudio 13.5.1 Mac
Puissant environnement de développement intégré PHP