我正在用java开发一个软件,它在接收到一个事件(来自传感器)时创建一个线程。这些线程的生存时间非常短(< 1 秒)
传感器每分钟最多发送 10 个事件。
这个应用程序大部分时间都可以正常工作。但有时它会挂起。
我查看了eclipse调试器,发现有很多线程,其中大多数是"Thread[garbage collected]"
(大约800个线程@_@)
我不知道该错误是由我的代码中的动态创建线程还是其他错误引起的?
EDIT:
该问题确实是由创建太多线程引起的。我已经用时间戳记录了所有传感器的事件,并且它创建了一些关于1200 events/minute
(该死的!)的点。
我还编写了一个小型 Java 程序,它可以创建尽可能多的线程。在~4100th thread
(嗯,木制计算机),jvm 崩溃。它不像我的应用程序那样挂起:-?。
因此,我认为在动态创建线程时存在(可能)罕见的情况,它会导致垃圾收集线程挂起?