首先先贴出这个异常的部分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) {
......
}
}
如此,导致了死锁。