java调试多线程时出现混乱,Java中的多线程调试

我有一个运行大约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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值