牛骨文教育服务平台(让学习变的简单)
博文笔记

Java 异常处理 之:java.lang.StackOverflowError

创建时间:2016-10-14 投稿人: 浏览次数:2440

首先先贴出这个异常的部分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) {

......

       }

}

如此,导致了死锁。


声明:该文观点仅代表作者本人,牛骨文系教育信息发布平台,牛骨文仅提供信息存储空间服务。