wilddonkey 2011-05-10 16:06
浏览 240
已采纳

关于java线程sleep的问题

很多资料上都说sleep 不会释放锁.我做了一个小例子,感觉有点晕


public class Test2 extends Thread {
int b = 100;

public void m1() throws InterruptedException { 

    System.out.println("m1 enter..");
    synchronized (this) { 
        System.out.println("m1 enter synchronized block..");
        b = 200;
        Thread.sleep(5000);//?
        System.out.println("b= " + b);
    }
}

public  void m2() throws InterruptedException {
    System.out.println("m2 enter..");
    b = 500;
}

public void run() {
    System.out.println("runing ...");
    try {
        m1();
    } catch (InterruptedException e) {

        e.printStackTrace();
    }
}

public static void main(String[] args) throws InterruptedException {
    Test2 t = new Test2();

    t.start();

    Thread.sleep(2000);
    t.m2();

}

}


输出结果如下:
runing ...
m1 enter..
m1 enter synchronized block..
m2 enter..
b= 500

我怎么感觉最后一行输出 应该是 100呢.还有m1方法进入同步块后居然还执行m2方法了是怎么回事?
如果给m2方法 加 synchronized,结果是我想要的,想不明白....
  • 写回答

7条回答 默认 最新

  • etank2011 2011-05-11 16:40
    关注

    [quote]
    我怎么感觉最后一行输出 应该是 100呢.还有m1方法进入同步块后居然还执行m2方法了是怎么回事?
    如果给m2方法 加 synchronized,结果是我想要的,想不明白....[/quote]

    这个结果的原因是m2没有去争取this的锁,所以和m1没有任何冲突关系

    关于sync(this)这句语句需要理解下,其实没有java对象有一个唯一的锁关联,sync就是去获取这个锁,指定this也就是获取this相关的锁,m1获得了,而m2不需要获得,所以跟m1有没有释放锁没有任何关系
    而对m2加了sync(this)以后,m2需要先获得this的锁才能进入sync块,所以必须m1先执行完sync块并释放锁对象

    需要同步的线程必须关联到相同的锁对象上才可能(当然绕圈的锁关系其实最后还是要到同一锁上)

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(6条)

报告相同问题?

悬赏问题

  • ¥15 RPA正常跑,cmd输入cookies跑不出来
  • ¥15 求帮我调试一下freefem代码
  • ¥15 matlab代码解决,怎么运行
  • ¥15 R语言Rstudio突然无法启动
  • ¥15 关于#matlab#的问题:提取2个图像的变量作为另外一个图像像元的移动量,计算新的位置创建新的图像并提取第二个图像的变量到新的图像
  • ¥15 改算法,照着压缩包里边,参考其他代码封装的格式 写到main函数里
  • ¥15 用windows做服务的同志有吗
  • ¥60 求一个简单的网页(标签-安全|关键词-上传)
  • ¥35 lstm时间序列共享单车预测,loss值优化,参数优化算法
  • ¥15 Python中的request,如何使用ssr节点,通过代理requests网页。本人在泰国,需要用大陆ip才能玩网页游戏,合法合规。