Maison Java Javacommencer Quelles sont les différences entre les verrous Java ?

Quelles sont les différences entre les verrous Java ?

Nov 12, 2019 pm 04:31 PM
java 区别

Quelles sont les différences entre les verrous Java ?

Verrouillage équitable/verrouillage injuste

Le verrouillage équitable signifie que plusieurs threads acquièrent le verrou dans l'ordre pour lequel ils demandent il se verrouille.

Un verrouillage injuste signifie que l'ordre dans lequel plusieurs threads acquièrent des verrous n'est pas dans l'ordre dans lequel ils demandent des verrous. Il est possible que le thread qui a appliqué plus tard acquière le verrou avant le thread qui a appliqué en premier. Il est possible que cela provoque une inversion des priorités ou une famine.

Pour Java ReentrantLock, spécifiez si le verrou est un verrou équitable via le constructeur, et la valeur par défaut est un verrou injuste. L’avantage des verrous injustes est que le débit est supérieur à celui des verrous équitables.

Pour Synchronized, c'est aussi un verrouillage injuste. Puisqu'il n'implémente pas la planification des threads via AQS comme ReentrantLock, il n'y a aucun moyen de le transformer en un verrou équitable.

Verrouillage réentrant

Le verrouillage réentrant, également appelé verrouillage récursif, signifie que lorsque le même thread acquiert le verrou dans la méthode externe, il entre dans la méthode interne Le verrou sera acquis automatiquement. C'est un peu abstrait, mais il y a un exemple de code ci-dessous.

Pour Java ReentrantLock, son nom peut être vu comme un verrou réentrant, et son nom est Reentrant Lock.

Pour Synchronisé, c'est aussi un verrou réentrant. L’un des avantages des verrous réentrants est que les blocages peuvent être évités dans une certaine mesure.

synchronized void setA() throws Exception{
    Thread.sleep(1000);
    setB();
}
synchronized void setB() throws Exception{
    Thread.sleep(1000);
}
Copier après la connexion

Le code ci-dessus est une fonctionnalité d'un verrou réentrant. S'il ne s'agit pas d'un verrou réentrant, setB peut ne pas être exécuté par le thread actuel, ce qui peut provoquer un blocage.

Verrouillage exclusif/verrouillage partagé

Le verrouillage exclusif signifie que le verrou ne peut être détenu que par un seul thread à la fois.

Le verrouillage partagé signifie que le verrou peut être détenu par plusieurs threads.

Pour Java ReentrantLock, c'est un verrou exclusif. Mais pour une autre classe d'implémentation de Lock, ReadWriteLock, son verrou en lecture est un verrou partagé et son verrou en écriture est un verrou exclusif.

Le verrou partagé du verrou de lecture garantit que la lecture simultanée est très efficace et que les processus de lecture, d'écriture, d'écriture et d'écriture s'excluent mutuellement.

Les verrous exclusifs et partagés sont également implémentés via AQS, et différentes méthodes sont mises en œuvre pour obtenir des verrous exclusifs ou partagés.

Pour Synchronized, il s'agit bien sûr d'un verrou exclusif.

Verrouillage mutex/verrouillage en lecture-écriture

Le verrouillage exclusif/verrouillage partagé mentionné ci-dessus est un terme large, et le verrouillage mutex/verrouillage en lecture-écriture est une réalisation spécifique .

L'implémentation spécifique du verrouillage mutex en Java est ReentrantLock.

L'implémentation spécifique du verrouillage en lecture-écriture en Java est ReadWriteLock.

Verrouillage optimiste/verrouillage pessimiste

Le verrouillage optimiste et le verrouillage pessimiste ne font pas référence à des types spécifiques de verrous, mais à la perspective de visualisation de la concurrence et de la synchronisation.

Le verrouillage pessimiste estime que les opérations simultanées sur les mêmes données seront définitivement modifiées. Même s'il n'y a pas de modification, elles seront considérées comme modifiées. Ainsi, pour les opérations concurrentes sur les mêmes données, le verrouillage pessimiste prend la forme d'un verrouillage. Pessimiste, je pense que les opérations simultanées sans verrouillage poseront certainement des problèmes.

Le verrouillage optimiste estime que les opérations simultanées sur les mêmes données ne seront pas modifiées. Lors de la mise à jour des données, les données seront mises à jour en essayant de mettre à jour et de mettre à jour constamment les données. Avec un peu d'optimisme, il n'y aura aucun problème avec les opérations simultanées sans verrouillage.

D'après la description ci-dessus, nous pouvons voir que le verrouillage pessimiste convient aux scénarios avec de nombreuses opérations d'écriture, et le verrouillage optimiste convient aux scénarios avec de nombreuses opérations de lecture. Ne pas verrouiller apportera beaucoup de performances. améliorations.

L'utilisation du verrouillage pessimiste en Java consiste à utiliser différents verrous.

L'utilisation du verrouillage optimiste en Java est une programmation sans verrouillage, et l'algorithme CAS est souvent utilisé. Un exemple typique est la classe atomique, qui implémente la mise à jour des opérations atomiques via CAS spin.

Verrouillage segmenté

Le verrouillage segmenté est en fait une conception de verrouillage, pas un verrou spécifique. Pour ConcurrentHashMap, sa mise en œuvre simultanée est efficace. Les opérations simultanées sont réalisées grâce à des verrous segmentés.

Prenons ConcurrentHashMap pour parler de la signification et de l'idée de conception du verrouillage de segment. Le verrouillage de segment dans ConcurrentHashMap est appelé Segment, qui est similaire à la structure de HashMap (l'implémentation de HashMap dans JDK7 et JDK8). , c'est-à-dire que l'interne Il a un tableau Entry, et chaque élément du tableau est une liste chaînée, c'est aussi un ReentrantLock (le segment hérite de ReentrantLock).

Lorsque vous devez mettre un élément, il ne verrouille pas l'intégralité du hashmap, mais utilise d'abord le hashcode pour savoir dans quel segment il doit être placé, puis verrouille ce segment, donc quand quand multi-thread est mis , tant qu'il n'est pas placé dans un segment, une véritable insertion parallèle est obtenue.

Cependant, lors du comptage de la taille, lors de l'obtention des informations globales de hashmap, vous devez obtenir tous les verrous de segment pour compter.

Le but de la conception du verrouillage segmenté est d'affiner la granularité du verrouillage. Lorsque l'opération n'a pas besoin de mettre à jour l'intégralité du tableau, un seul élément du tableau est verrouillé.

Verrouillage biais/Verrouillage léger/Verrouillage lourd

Ces trois types de verrous font référence à l'état du verrou et sont destinés à être synchronisés. Dans Java 5, une synchronisation efficace est obtenue en introduisant un mécanisme de mise à niveau du verrouillage. L'état de ces trois verrous est indiqué par les champs dans l'en-tête d'objet du moniteur d'objets.

Le verrouillage biaisé signifie qu'un morceau de code de synchronisation est toujours accédé par un thread, puis le thread acquerra automatiquement le verrou. Réduisez le coût d’acquisition des serrures.

Le verrouillage léger signifie que lorsque le verrou est un verrou biaisé et qu'un autre thread y accède, le verrou biaisé sera mis à niveau vers un verrou léger. D'autres threads tenteront d'acquérir le verrou via la rotation sans bloquer, améliorant ainsi les performances.

Un verrou lourd signifie que lorsque le verrou est un verrou léger, même si un autre fil tourne, la rotation ne continuera pas éternellement. Lorsqu'il tourne un certain nombre de fois, il n'a pas encore été acquis. entrera en blocage et le verrou se développera en un verrou lourd. Les verrous lourds bloqueront d’autres threads d’application et réduiront les performances.

Spin lock

En Java, un spin lock signifie que le thread essayant d'acquérir le verrou ne se bloquera pas immédiatement, mais tentera d'acquérir le verrou en boucle , l'avantage est de réduire la consommation de changement de contexte de thread, mais l'inconvénient est que la boucle consomme du CPU.

Site Web php chinois, un grand nombre de Tutoriels d'introduction à Java gratuits, bienvenue pour apprendre en ligne !

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

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Comment déverrouiller tout dans Myrise
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

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

La différence entre char et wchar_t dans le langage C La différence entre char et wchar_t dans le langage C Apr 03, 2025 pm 03:09 PM

Dans le langage C, la principale différence entre Char et WCHAR_T est le codage des caractères: Char utilise ASCII ou étend ASCII, WCHAR_T utilise Unicode; Char prend 1 à 2 octets, WCHAR_T occupe 2-4 octets; Char convient au texte anglais, WCHAR_T convient au texte multilingue; Le char est largement pris en charge, WCHAR_T dépend de la prise en charge du compilateur et du système d'exploitation Unicode; Le char est limité dans la gamme de caractères, WCHAR_T a une gamme de caractères plus grande et des fonctions spéciales sont utilisées pour les opérations arithmétiques.

La différence entre le multithreading et le C # asynchrone La différence entre le multithreading et le C # asynchrone Apr 03, 2025 pm 02:57 PM

La différence entre le multithreading et l'asynchrone est que le multithreading exécute plusieurs threads en même temps, tandis que les opérations effectuent de manière asynchrone sans bloquer le thread actuel. Le multithreading est utilisé pour les tâches à forte intensité de calcul, tandis que de manière asynchrone est utilisée pour l'interaction utilisateur. L'avantage du multi-threading est d'améliorer les performances informatiques, tandis que l'avantage des asynchrones est de ne pas bloquer les threads d'interface utilisateur. Le choix du multithreading ou asynchrone dépend de la nature de la tâche: les tâches à forte intensité de calcul utilisent le multithreading, les tâches qui interagissent avec les ressources externes et doivent maintenir la réactivité de l'interface utilisateur à utiliser asynchrone.

Quelles sont les exigences de base pour les fonctions de langue C Quelles sont les exigences de base pour les fonctions de langue C Apr 03, 2025 pm 10:06 PM

Les fonctions de langue C sont la base de la modularisation du code et de la construction de programmes. Ils se composent de déclarations (en-têtes de fonction) et de définitions (corps de fonction). Le langage C utilise des valeurs pour transmettre les paramètres par défaut, mais les variables externes peuvent également être modifiées à l'aide d'adresse Pass. Les fonctions peuvent avoir ou ne pas avoir de valeur de retour et le type de valeur de retour doit être cohérent avec la déclaration. La dénomination de la fonction doit être claire et facile à comprendre, en utilisant un chameau ou une nomenclature de soulignement. Suivez le principe de responsabilité unique et gardez la simplicité de la fonction pour améliorer la maintenabilité et la lisibilité.

Quelle est la différence entre char et char non signé Quelle est la différence entre char et char non signé Apr 03, 2025 pm 03:36 PM

Le char et le char non signé sont deux types de données qui stockent les données des caractères. La principale différence est le moyen de gérer les nombres négatifs et positifs: plage de valeur: char signé (-128 à 127), et Char non signé Unsigned (0 à 255). Traitement du nombre négatif: le char peut stocker des nombres négatifs, le char non signé ne peut pas. Mode bit: Char le bit le plus élevé représente le symbole, un bit non signé non signé. Opérations arithmétiques: le char et le char non signé sont signés et non signés, et leurs opérations arithmétiques sont différentes. Compatibilité: char et char non signé

La différence entre H5 et mini-programmes et applications La différence entre H5 et mini-programmes et applications Apr 06, 2025 am 10:42 AM

H5. La principale différence entre les mini programmes et l'application est: Architecture technique: H5 est basé sur la technologie Web, et les mini-programmes et l'application sont des applications indépendantes. Expérience et fonctions: H5 est légère et facile à utiliser, avec des fonctions limitées; Les mini-programmes sont légers et ont une bonne interactivité; Les applications sont puissantes et ont une expérience fluide. Compatibilité: H5 est compatible multiplateforme, les applets et les applications sont limités par la plate-forme. Coût de développement: H5 a un faible coût de développement, des mini-programmes moyens et une application la plus élevée. Scénarios applicables: H5 convient à l'affichage d'informations, les applets conviennent aux applications légères et les applications conviennent aux fonctions complexes.

Quelles sont les différences et les connexions entre C et C #? Quelles sont les différences et les connexions entre C et C #? Apr 03, 2025 pm 10:36 PM

Bien que C et C # aient des similitudes, ils sont complètement différents: C est une gestion manuelle de la mémoire manuelle et un langage dépendant de la plate-forme utilisé pour la programmation système; C # est un langage orienté objet, des ordures et un langage indépendant de la plate-forme utilisé pour le bureau, l'application Web et le développement de jeux.

Comment utiliser XPath pour rechercher à partir d'un nœud DOM spécifié en JavaScript? Comment utiliser XPath pour rechercher à partir d'un nœud DOM spécifié en JavaScript? Apr 04, 2025 pm 11:15 PM

Explication détaillée de la méthode de recherche XPATH sous les nœuds DOM en JavaScript, nous devons souvent trouver des nœuds spécifiques de l'arbre Dom basé sur les expressions XPath. Si vous avez besoin de ...

c Quelles sont les différences entre les trois méthodes de mise en œuvre de la lecture multithre c Quelles sont les différences entre les trois méthodes de mise en œuvre de la lecture multithre Apr 03, 2025 pm 03:03 PM

Le multithreading est une technologie importante dans la programmation informatique et est utilisée pour améliorer l'efficacité de l'exécution du programme. Dans le langage C, il existe de nombreuses façons d'implémenter le multithreading, y compris les bibliothèques de threads, les threads POSIX et l'API Windows.

See all articles