黑马程序员技术交流社区
标题:
面试题,帮忙解决一下 啊,谢谢啦
[打印本页]
作者:
yangsing0
时间:
2014-11-1 19:03
标题:
面试题,帮忙解决一下 啊,谢谢啦
下面的代码在绝大部分时间内都运行得很正常,请问在什么情况下会出现问题?问题的根源在哪里?(10)
import java.util.LinkedList;
public class Stack {
LinkedList list = new LinkedList();
public synchronized void push(Object x) {
synchronized(list) {
list.addLast( x );
notify();
}
}
public synchronized Object pop()
throws Exception {
synchronized(list) {
if( list.size() <= 0 ) {
wait();
}
return list.removeLast();
}
}
}
// dead lock, synchronized on both 'list' and 'this'
作者:
刘一博
时间:
2014-11-2 10:47
你在方法和list上都加锁了,方法上的锁没有必要吧
作者:
姜浩
时间:
2014-11-2 10:53
lz的代码是为了写死锁吗?
多线程中死锁的出现:是因为同步代码块的嵌套。
多个线程因要获取对方的锁而僵持不下,最终造成了永久堵塞的状态。也就是死锁。
java中没有办法发现和避免死锁的出现,所以只能在编写代码的时候注意,
尽量只在多个线程操作一份共享数据时,使用同步代码块,避免同步中嵌套同步。
作者:
inception
时间:
2014-11-2 13:04
方法上和方法内都写了synchronized.一般运行都没问题。
问在什么情况下会出问题。
如果一个线程中的run方法中调用这两个方法应该会出问题
欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/)
黑马程序员IT技术论坛 X3.2