【问题标题】:Understanding Deadlock,Synchronization [duplicate]了解死锁,同步[重复]
【发布时间】:2014-08-04 13:52:05
【问题描述】:

我最近在 oracle 网站的 java 教程上阅读并发。今天我阅读了关于死锁/同步的内容,我能够理解一些事情。

同步:

同步方法:没有两个线程可以调用同一对象的两个不同的同步方法。意味着在给定的时间点,即使有多个其他同步方法,每个对象也只能执行一个同步方法。

我的理解是否正确。

死锁:

在下面的代码中死锁,但我就是不明白为什么?为什么两个线程都在等待对方退出弓法?

package com.tutorial;

public class Deadlock {
    static class Friend {
        private final String name;
        public Friend(String name) {
            this.name = name;
        }
        public String getName() {
            return this.name;
        }
        public synchronized void bow(Friend bower) {
            System.out.format("%s: %s"
                + "  has bowed to me!%n", 
                this.name, bower.getName());
            bower.bowBack(this);
        }
        public synchronized void bowBack(Friend bower) {
            System.out.format("%s: %s"
                + " has bowed back to me!%n",
                this.name, bower.getName());
        }
    }

    public static void main(String[] args) {
        final Friend alphonse =
            new Friend("Alphonse");
        final Friend gaston =
            new Friend("Gaston");
        new Thread(new Runnable() {
            public void run() { alphonse.bow(gaston); }
        }).start();
       new Thread(new Runnable() {
            public void run() { gaston.bow(alphonse); }
        }).start();
    }
}

【问题讨论】:

    标签: java multithreading


    【解决方案1】:
    1. alphonse.bow(锁定 apohonse)
    2. gaston.bow(锁定 gaston)
    3. alphonse.bow 调用 gaston.bowback(无法锁定 gaston,因为在 alphonse 的线程中所以被阻塞但持有 alphonse 锁)
    4. gaston.bow 调用 alphose.bowback(无法锁定 alphonse,因为在 gaston 的线程中因此被阻塞但持有 gaston 锁定)

    死锁

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2018-05-07
      • 2021-03-26
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多