我看到这样的评论
我见过这个问题的一个地方是,如果您继续创建线程,而不是直接在线程对象上调用run(),而不是调用start()。这将导致线程对象不被取消引用…因此,一段时间后,出现无法创建新本机线程的消息
在Sun Java论坛上
在我的应用程序中,最初我们计划使用线程,但是后来,我们决定不再需要线程,因此我们只调用run()而不是start()。我们是否需要为新的threadClass(..)做手动GC?
我的tomcat启动设置
-Xms1024m -Xmx1024m -XX:MaxPermSize=450m
为什么首先创建一个Thread
?
您的代码应Runnable
改为实现接口。
然后,当您决定要在线程中运行它时,可以简单地实例化一个Thread
以Runnable
作为参数,并调用start()
该Thread
对象。
相反,如果您只想在当前线程中运行它,则只需调用run()
您的Runnable
对象即可。
这有几个优点:
Thread
对象,只要您不关心单独的线程Runnable
从概念上更适合的方式中:您不是在编写某种特殊的线程,对吗?您只需编写一些可以执行/运行的代码。Executor
,进一步简化决策最后但并非最不重要的一点是,您可以避免在是否创建本机线程资源方面造成任何潜在的混淆。
我试图在(1and1VPS)上运行服务器。就在服务器启动和客户机的几个请求(重新加载网页)之后,我得到了这个错误: 但是当我在计算机上运行时,一切都正常。我使用和Centos5.8新安装制作了自己的虚拟服务器,它也在那里工作。 这个内存不足错误的原因可能是什么?如果你有任何建议,请分享。我不知道该怎么处理这个了。
它的发生是因为我创建了许多线程,而没有关闭它们?还是经常创造新的? 有人能告诉我在代码中是否做错了什么吗?
运行5-6小时后,我从spark-driver程序中得到以下错误。我正在使用Ubuntu16.04LTS和Open-JDK-8。 cat/proc/sys/kernel/threads-max “无法创建新的本机线程”显然意味着它与堆无关。所以我相信这更多的是一个操作系统的问题。
我目前正在安装一台新的MongoDB ops manager机器。安装工作正常,但我无法启动mongodb彩信服务。实例0的启动因java而失败。lang.OutOfMemoryError异常。我使用与测试服务器上相同的配置(2个CPU核,8gb ram),在那里服务启动时没有任何中断。更改ulimit配置/使用root用户启动服务无效。 新服务器规格: 2.0Ghz的10个Vcore 48gb内
我想在我的虚拟服务器上启动一个野蝇。每次我运行./wilfly/bin/standalone.sh我在无融资创业时都会收到以下错误: 让我得到以下信息: 如您所见,虚拟内存是无限的,最大用户进程非常大。 在启动本文中描述的jvm时,我还使用-Xss256kb增加/减少了堆栈大小,但没有任何成功。 同样在standalone.xml中为每个子系统增加50也不起作用(在本文中描述)。 您还有其他想法如