我有一个运行大约50个线程的程序.我采用生产者使用者设计模式在线程之间传递数据.程序运行了一段时间后,有时由于冻结我在线程之间分配数据所使用的BlockingQueue之一而冻结,因此程序尝试将数据添加到此BlockingQueue时,程序的主要分配部分将阻塞.换句话说,线程之一由于某种原因而停止,然后用于接收数据的blockingQueue变满.
我该如何高效调试呢?我尝试用catch(Exception e)将所有run()方法的内容都包含在内,但是没有抛出任何异常.我用Java / IntelliJ开发.
有什么想法,想法或一般准则吗?
解决方法:
通过使用记录器“调试”.我喜欢SLF4J.
在每个关键操作之前和之后设置log.debug语句.在每个方法的开头和结尾使用log.entering和log.exiting调用.
在“调试”期间,将记录器设置为非常低的级别(FINEST),然后运行应用程序,然后运行应用程序,并观察日志记录语句,以了解何时失败以及何时失败.
由于您担心线程问题,因此请确保您的日志格式包含线程名称或编号.
标签:multithreading,intellij-idea,java
来源: https://codeday.me/bug/20191120/2044268.html