Maison >développement back-end >Golang >Existe-t-il un modèle de verrouillage tamponné dans Go similaire aux canaux tamponnés ?

Existe-t-il un modèle de verrouillage tamponné dans Go similaire aux canaux tamponnés ?

Susan Sarandon
Susan Sarandonoriginal
2024-11-25 17:01:12232parcourir

Is There a Buffered Locking Pattern in Go Similar to Buffered Channels?

Modèle de verrouillage tamponné dans Go

Dans Go, un canal tamponné permet à la communication de continuer sans blocage jusqu'à ce que son tampon se remplisse. Cependant, existe-t-il un modèle similaire pour mettre en mémoire tampon les verrous qui limitent l'accès aux ressources à un nombre spécifique de clients ?

La primitive permettant de gérer l'accès simultané à une ressource est le sémaphore. Un sémaphore peut être facilement implémenté à l'aide d'un canal tamponné.

Voici un exemple :

var semaphore = make(chan struct{}, 4) // allow four concurrent users

func f() {
    // Grab the lock. Blocks if 4 other concurrent invocations of f are running.
    semaphore <- struct{}{}

    // Release the lock when the function is done.
    defer func() { <-semaphore }()

    // Perform the intended operations...
}

Dans cet exemple, un sémaphore avec un tampon de taille 4 est créé en utilisant semaphore := make( chan struct{}, 4). La fonction f() tente d'acquérir le verrou en envoyant une structure vide au canal. Si le tampon du canal est plein (c'est-à-dire que 4 instances simultanées de f() sont déjà en cours d'exécution), l'appel au sémaphore <- struct{}{} se bloque jusqu'à ce qu'un verrou devienne disponible.

Lorsque la fonction se termine sa tâche, il libère le verrou en récupérant une structure vide du canal (-

Ce modèle constitue un moyen pratique de restreindre l'accès à une ressource partagée à un nombre spécifique de clients simultanés, évitant ainsi d'éventuels problèmes de conflit de ressources.

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!

Déclaration:
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