


Analyse des mécanismes de blocage et de non-blocage des canaux Golang
Analyse des mécanismes de blocage et de non-blocage des canaux Golang
Introduction :
Les canaux sont l'un des mécanismes de communication simultanés importants dans Golang, qui permettent la communication et la synchronisation entre les différentes Goroutines. Lors de l’utilisation des chaînes, nous rencontrons souvent des situations bloquantes et non bloquantes. Cet article présentera les mécanismes de blocage et de non-blocage des canaux et illustrera ses principes et son utilisation à travers des exemples de code.
- Concepts de base du blocage et du non-blocage
En programmation simultanée, le blocage et le non-blocage sont deux méthodes de traitement courantes. En termes simples, le blocage signifie que lorsqu'un Goroutine essaie de lire ou d'écrire un canal, si le canal n'est pas prêt, alors le Goroutine sera bloqué jusqu'à ce que le canal soit prêt. Le non-blocage signifie que le Goroutine n'est pas prêt, que le canal soit prêt ou non ; Le canal est prêt. Dans ce cas, l'exécution continue immédiatement.
Dans Golang, nous pouvons implémenter des mécanismes de blocage et de non-blocage des deux manières suivantes : en utilisant la longueur du canal et en utilisant l'instruction select. Ci-dessous, nous les présenterons un par un.
- Utilisez la longueur du canal pour obtenir le blocage et le non-blocage
Pour le canal sans tampon, sa longueur est de 0. Lorsqu'un Goroutine tente d'écrire des données sur un canal sans tampon, s'il n'y a aucun autre Goroutine en attente de lecture sur le même canal, l'opération d'écriture sera bloquée jusqu'à ce qu'un Goroutine soit prêt à lire les données. De même, lorsqu'un Goroutine tente de lire des données à partir d'un canal sans tampon, l'opération de lecture sera bloquée s'il n'y a aucun autre Goroutine en attente d'écriture sur le même canal.
Exemple de code :
package main import "fmt" func main() { ch := make(chan int) // 创建一个无缓冲 Channel go func() { fmt.Println("开始写入数据") ch <- 1 // 写入数据到 Channel fmt.Println("数据写入成功") }() fmt.Println("等待读取数据") data := <-ch // 从 Channel 读取数据 fmt.Println("读取到数据:", data) }
Dans le code ci-dessus, nous créons un canal ch
sans tampon. Dans la fonction principale, nous démarrons une Goroutine qui écrit des données sur le canal ch
. Dans le Goroutine principal, nous essayons de lire les données du canal ch
, et comme il n'y a aucun autre Goroutine en attente d'écriture sur ce canal, l'opération de lecture est bloquée. L'opération de lecture ne continuera pas tant que le Goroutine qui a écrit les données n'aura pas fini de s'exécuter. ch
。在 main 函数中,我们启动了一个 Goroutine,该 Goroutine 会向 Channel ch
写入数据。在主 Goroutine 中,我们试图从 Channel ch
中读取数据,由于没有其他 Goroutine 在此 Channel 上等待写入,读取操作会被阻塞。直到写入数据的 Goroutine 执行完成后,读取操作才会继续执行。
- 利用 select 语句实现非阻塞
除了利用 Channel 的长度实现阻塞和非阻塞之外,Golang 中还提供了 select 语句,使得我们可以更灵活地处理并发通信。
在 select 语句中,我们可以同时监听多个 Channel 的读取和写入操作。当一个或多个 Channel 准备好时,select 语句会随机选择一个可执行的操作进行执行。如果没有任何 Channel 准备好,那么 select 语句会进入阻塞状态,直到至少有一个 Channel 准备好。
代码示例:
package main import "fmt" func main() { ch1 := make(chan int) ch2 := make(chan int) go func() { ch1 <- 1 }() go func() { ch2 <- 2 }() fmt.Println("开始监听 Channel") select { case data := <-ch1: fmt.Println("从 ch1 中读取到数据:", data) case data := <-ch2: fmt.Println("从 ch2 中读取到数据:", data) } }
在上述代码中,我们创建了两个 Channel ch1
和 ch2
- Utilisez l'instruction select pour obtenir le non-blocage
En plus d'utiliser la longueur du canal pour obtenir le blocage et le non-blocage, Golang fournit également des instructions select, nous permettant de gérer davantage les communications simultanées. avec souplesse.
Dans l'instruction select, nous pouvons surveiller les opérations de lecture et d'écriture de plusieurs canaux en même temps. Lorsqu'un ou plusieurs canaux sont prêts, l'instruction select sélectionne de manière aléatoire une opération exécutable à exécuter. Si aucun canal n'est prêt, l'instruction select entrera dans l'état de blocage jusqu'à ce qu'au moins un canal soit prêt.
- Exemple de code :
- rrreee Dans le code ci-dessus, nous avons créé deux canaux
- Conclusion :
ch1
et ch2
, et démarré deux Goroutines respectivement sur les deux canaux d'écriture de données. Dans le Goroutine principal, nous utilisons l'instruction select pour sélectionner une opération exécutable à partir de plusieurs canaux. Puisque les deux canaux sont prêts, l'instruction select sélectionnera au hasard l'une des opérations exécutables à exécuter. 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!

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

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Lire et écrire des fichiers en toute sécurité dans Go est crucial. Les directives incluent : Vérification des autorisations de fichiers Fermeture de fichiers à l'aide de reports Validation des chemins de fichiers Utilisation de délais d'attente contextuels Le respect de ces directives garantit la sécurité de vos données et la robustesse de vos applications.

Comment configurer le pool de connexions pour les connexions à la base de données Go ? Utilisez le type DB dans le package base de données/sql pour créer une connexion à la base de données ; définissez MaxOpenConns pour contrôler le nombre maximum de connexions simultanées ; définissez MaxIdleConns pour définir le nombre maximum de connexions inactives ; définissez ConnMaxLifetime pour contrôler le cycle de vie maximum de la connexion ;

Le framework Go se distingue par ses hautes performances et ses avantages en matière de concurrence, mais il présente également certains inconvénients, tels qu'être relativement nouveau, avoir un petit écosystème de développeurs et manquer de certaines fonctionnalités. De plus, les changements rapides et les courbes d’apprentissage peuvent varier d’un cadre à l’autre. Le framework Gin est un choix populaire pour créer des API RESTful en raison de son routage efficace, de sa prise en charge JSON intégrée et de sa puissante gestion des erreurs.

La différence entre le framework GoLang et le framework Go se reflète dans l'architecture interne et les fonctionnalités externes. Le framework GoLang est basé sur la bibliothèque standard Go et étend ses fonctionnalités, tandis que le framework Go se compose de bibliothèques indépendantes pour atteindre des objectifs spécifiques. Le framework GoLang est plus flexible et le framework Go est plus facile à utiliser. Le framework GoLang présente un léger avantage en termes de performances et le framework Go est plus évolutif. Cas : gin-gonic (framework Go) est utilisé pour créer l'API REST, tandis qu'Echo (framework GoLang) est utilisé pour créer des applications Web.

Les données JSON peuvent être enregistrées dans une base de données MySQL à l'aide de la bibliothèque gjson ou de la fonction json.Unmarshal. La bibliothèque gjson fournit des méthodes pratiques pour analyser les champs JSON, et la fonction json.Unmarshal nécessite un pointeur de type cible pour désorganiser les données JSON. Les deux méthodes nécessitent la préparation d'instructions SQL et l'exécution d'opérations d'insertion pour conserver les données dans la base de données.

Meilleures pratiques : créer des erreurs personnalisées à l'aide de types d'erreurs bien définis (package d'erreurs) fournir plus de détails consigner les erreurs de manière appropriée propager correctement les erreurs et éviter de masquer ou de supprimer les erreurs Wrap si nécessaire pour ajouter du contexte

La fonction FindStringSubmatch recherche la première sous-chaîne correspondant à une expression régulière : la fonction renvoie une tranche contenant la sous-chaîne correspondante, le premier élément étant la chaîne entière correspondante et les éléments suivants étant des sous-chaînes individuelles. Exemple de code : regexp.FindStringSubmatch(text,pattern) renvoie une tranche de sous-chaînes correspondantes. Cas pratique : Il peut être utilisé pour faire correspondre le nom de domaine dans l'adresse email, par exemple : email:="user@example.com", pattern:=@([^\s]+)$ pour obtenir la correspondance du nom de domaine [1].

Chemin d'apprentissage du backend: le parcours d'exploration du front-end à l'arrière-end en tant que débutant back-end qui se transforme du développement frontal, vous avez déjà la base de Nodejs, ...
