


Comment utiliser synchronisé pour implémenter le mécanisme de synchronisation en Java ?
Résumé de l'utilisation de synchronisé en Java
1. Lors de l'utilisation de synchronisé comme modificateur de fonction, l'exemple de code est le suivant :
Public synchronized void method(){ //…. }
C'est la méthode de synchronisation. Alors, quel objet est verrouillé par synchronisé à ce moment-là ? Ce qu'il verrouille appelle cet objet méthode synchronisée. En d'autres termes, lorsqu'un objet P1 exécute cette méthode de synchronisation dans différents threads, une exclusion mutuelle sera formée entre eux pour obtenir un effet de synchronisation. Cependant, un autre objet P2 généré par la Classe à laquelle appartient cet objet peut arbitrairement appeler cette méthode en ajoutant le mot-clé synchronisé.
L'exemple de code ci-dessus est équivalent au code suivant :
public void method() { synchronized (this) // (1) { //….. } }
À quoi fait référence ce point (1) ? Il fait référence à l'objet qui appelle cette méthode, comme P1. On peut voir que l'essence de la méthode de synchronisation est d'appliquer la synchronisation à la référence d'objet. ——Seul le thread qui a obtenu le verrou d'objet P1 peut appeler la méthode de synchronisation de P1. En ce qui concerne P2, le verrou P1 n'a rien à voir avec cela. Le programme peut également se débarrasser du contrôle du mécanisme de synchronisation. dans ce cas, cela entraîne une confusion des données.
2. Bloc de synchronisation, l'exemple de code est le suivant :
public void method(SomeObject so) { synchronized(so) { //….. } }
À ce stade, le verrou est l'objet so, et celui qui obtient le verrou peut exécuter le code qu'il contrôle. Lorsqu'il y a un objet clair comme verrou, vous pouvez écrire le programme comme ceci, mais lorsqu'il n'y a pas d'objet clair comme verrou et que vous souhaitez simplement synchroniser un morceau de code, vous pouvez créer une variable d'instance spéciale (elle doit être un objet) pour agir comme le verrou :
class Foo implements Runnable { private byte[] lock = new byte[0]; // 特别的instance变量 Public void method() { synchronized(lock) { //… } } //….. }
Remarque : un objet tableau d'octets de longueur nulle sera plus économique à créer que n'importe quel objet - regardez le bytecode compilé : générer un objet byte[] de longueur nulle ne nécessite que 3 opcodes , et Object lock = new Object () nécessite 7 lignes d'opcode.
3. Appliquer synchronisé à une fonction statique. L'exemple de code est le suivant :
Class Foo { public synchronized static void method1() // 同步的static 函数 { //…. } public void method2() { synchronized(Foo.class) // class literal(类名称字面常量) } }
La méthode method2() dans le code utilise un littéral de classe comme verrou. Elle a le même effet que la fonction statique synchronisée, et le verrou obtenu est. très spécial. , est la classe à laquelle appartient l'objet qui appelle actuellement cette méthode (Classe, plutôt qu'un objet spécifique généré par cette Classe).
Je me souviens avoir lu dans le livre "Effective Java" que l'utilisation de Foo.class et P1.getClass() pour les verrous de synchronisation n'est pas la même chose. Vous ne pouvez pas utiliser P1.getClass() pour atteindre l'objectif de verrouiller cette classe. P1 fait référence à l'objet généré par la classe Foo.
Cela peut être déduit : si une fonction statique synchronisée A est définie dans une classe et qu'une fonction d'instance synchronisée B est également définie, alors lorsque le même objet Obj de cette classe accède respectivement aux méthodes A et B dans plusieurs threads, il non Cela constitue une synchronisation car leurs verrous sont tous différents. Le verrou de la méthode A est la classe à laquelle appartient Obj, et le verrou de la méthode B est l'objet auquel appartient Obj.
Un résumé de la façon d'utiliser synchronisé en Java est le suivant :
Comprendre quels verrous synchronisés d'objets peut nous aider à concevoir des programmes multithread plus sûrs.
Il existe également certaines techniques qui peuvent rendre plus sécurisé notre accès synchrone aux ressources partagées :
1. Définissez des variables d'instance privées + leurs méthodes get au lieu de variables d'instance publiques/protégées. Si la variable est définie comme publique, l'objet peut l'obtenir directement et la modifier depuis le monde extérieur, en contournant le contrôle de la méthode de synchronisation. C'est également l'une des méthodes d'implémentation standard de JavaBean.
2. Si la variable d'instance est un objet, tel qu'un tableau ou ArrayList, alors la méthode ci-dessus n'est toujours pas sûre, car lorsque l'objet externe obtient la référence de l'objet d'instance via la méthode get et la pointe vers un autre objet, alors la variable privée est-ce que si ça change, ne serait-ce pas dangereux ? À ce stade, vous devez ajouter une synchronisation synchronisée à la méthode get et renvoyer uniquement le clone() de cet objet privé - de cette manière, l'appelant obtient une référence à la copie de l'objet.
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)

Guide de la racine carrée en Java. Nous discutons ici du fonctionnement de Square Root en Java avec un exemple et son implémentation de code respectivement.

Guide du nombre parfait en Java. Nous discutons ici de la définition, comment vérifier le nombre parfait en Java ?, des exemples d'implémentation de code.

Guide du générateur de nombres aléatoires en Java. Nous discutons ici des fonctions en Java avec des exemples et de deux générateurs différents avec d'autres exemples.

Guide de Weka en Java. Nous discutons ici de l'introduction, de la façon d'utiliser Weka Java, du type de plate-forme et des avantages avec des exemples.

Guide du nombre de Smith en Java. Nous discutons ici de la définition, comment vérifier le numéro Smith en Java ? exemple avec implémentation de code.

Dans cet article, nous avons conservé les questions d'entretien Java Spring les plus posées avec leurs réponses détaillées. Pour que vous puissiez réussir l'interview.

Java 8 présente l'API Stream, fournissant un moyen puissant et expressif de traiter les collections de données. Cependant, une question courante lors de l'utilisation du flux est: comment se casser ou revenir d'une opération FOREAK? Les boucles traditionnelles permettent une interruption ou un retour précoce, mais la méthode Foreach de Stream ne prend pas directement en charge cette méthode. Cet article expliquera les raisons et explorera des méthodes alternatives pour la mise en œuvre de terminaison prématurée dans les systèmes de traitement de flux. Lire plus approfondie: Améliorations de l'API Java Stream Comprendre le flux Forach La méthode foreach est une opération terminale qui effectue une opération sur chaque élément du flux. Son intention de conception est

Guide de TimeStamp to Date en Java. Ici, nous discutons également de l'introduction et de la façon de convertir l'horodatage en date en Java avec des exemples.
