我是靠谱客的博主 发嗲石头,最近开发中收集的这篇文章主要介绍java.lang.InternalError: Thread starting during runtime shutdown,觉得挺不错的,现在分享给大家,希望可以做个参考。
概述
前段时间写一个小项目练手,在使用UncaughtExceptionHandler上传错误报告的时候一直出现java.lang.InternalError: Thread starting during runtime shutdown这样一个异常,百思不得其解,后来在StackOverFlow上找到了解决办法,决定记录下来。
java.lang.InternalError: Thread starting during runtime shutdown at java.lang.Thread.nativeCreate(Native Method)
at java.lang.Thread.start(Thread.java:1042) at org.apache.http.impl.conn.tsccm.AbstractConnPool.enableConnectionGC(AbstractConnPool.java:140)
at org.apache.http.impl.conn.tsccm.ThreadSafeClientConnManager.createConnectionPool(ThreadSafeClientConnManager.java:120)
at org.apache.http.impl.conn.tsccm.ThreadSafeClientConnManager.<init>(ThreadSafeClientConnManager.java:98)
StackOverFlow中大神的解释是:当前线程开启的太晚,也就是说当我在UncaughtExceptionHandler接收到未捕获的异常时,开启一个子线程来上传错误日志,在上传错误日志时创建了HttpClient,但是HttpClient在创建时设置了ThreadSafeClientConnManager来管理连接,通过查看ThreadSafeClientConnManager的源码发现,ThreadSafeClientConnManager也开启了子线程,这就出现了在子线程中开启子线程的问题,这就会导致uncaughtException()在执行完成后线程中的线程才开启,就会抛出java.lang.InternalError: Thread starting during runtime shutdown。
这个问题的解决方案是:提前创建HttpClient,因为HttpClient创建是也会开启线程,避免在uncaughtException()中创建,从而避免了在线程中开启线程的问题。
最后
以上就是发嗲石头为你收集整理的java.lang.InternalError: Thread starting during runtime shutdown的全部内容,希望文章能够帮你解决java.lang.InternalError: Thread starting during runtime shutdown所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复