java 1000个线程_关于Java多线程的一个问题

声明要同步的方法时,例如:

public synchronized void foo() {

// Do something

}

编译器将它看作是你写的:

public void foo() {

synchronized (this) {

// Do something

}

}

在您的示例中,您有一个同步方法和一个非同步方法.这意味着只会锁定对method1的访问权限.锁定检查仅在进入同步块时完成,因此调用method2不会触发任何锁定.

为了回答你的两个问题,那么,在这两种情况下,两个线程都将被允许继续,因为它们并不试图获得对同一对象的锁定.如果声明方法2要同步(或手动添加同步(此)块),则会强制一个线程等待另一个线程.

请记住:同步对象不会阻止其他线程调用该对象上的方法.它仅阻止另一个线程进入具有相同锁定对象的同步块.

顺便提一下,拥有内部锁定对象通常更好,而不是声明要同步的方法,例如,

class Foo {

private final Object LOCK = new Object();

public void doSomething() {

synchronized (LOCK) {

// Whatever

}

}

}

否则我可以通过这样做来打破你的线程安全:

class MessEverythingUp {

public MessEverythingUp(Foo foo) {

synchronized (foo) {

while (true) {

System.out.println("Pwnd ur thread safety");

}

}

}

}

因为我正在锁定foo的实例,所以你的synchronized方法(带有隐式的“synchronized(this)”)将无法获得锁定并将永久阻塞.最重要的是,你不能阻止这种情况,因为我可以同步任何我喜欢的对象.显然这个例子是极端的,但如果你不小心这种事情,你可能会得到令人讨厌的,微妙的死锁错误.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值