Java 异常处理 之:java.lang.StackOverflowError
首先先贴出这个异常的部分log:
java.lang.StackOverflowError at java.util.concurrent.locks.ReentrantLock$NonfairSync.lock(ReentrantLock.java:177) at java.util.concurrent.locks.ReentrantLock.lock(ReentrantLock.java:256) at java.util.concurrent.LinkedBlockingQueue.offer(LinkedBlockingQueue.java:386) at a.a.a.a$a.a(ExceedWait.java:118) at a.a.a.a$b.rejectedExecution(ExceedWait.java:42) at java.util.concurrent.ThreadPoolExecutor.reject(ThreadPoolExecutor.java:793) at java.util.concurrent.ThreadPoolExecutor.execute(ThreadPoolExecutor.java:1339)
从log上,大约觉出是线程同步使用错误问题。
后来检查,发现了这个问题:
public void test1(){
synchronized(lock) {
test2();
}
}
public void test2(){
synchronized(lock) {
......
}
}
如此,导致了死锁。
声明:该文观点仅代表作者本人,牛骨文系教育信息发布平台,牛骨文仅提供信息存储空间服务。