<bdo id='0MHJl'></bdo><ul id='0MHJl'></ul>
    1. <tfoot id='0MHJl'></tfoot>
    2. <small id='0MHJl'></small><noframes id='0MHJl'>

    3. <legend id='0MHJl'><style id='0MHJl'><dir id='0MHJl'><q id='0MHJl'></q></dir></style></legend>
      <i id='0MHJl'><tr id='0MHJl'><dt id='0MHJl'><q id='0MHJl'><span id='0MHJl'><b id='0MHJl'><form id='0MHJl'><ins id='0MHJl'></ins><ul id='0MHJl'></ul><sub id='0MHJl'></sub></form><legend id='0MHJl'></legend><bdo id='0MHJl'><pre id='0MHJl'><center id='0MHJl'></center></pre></bdo></b><th id='0MHJl'></th></span></q></dt></tr></i><div id='0MHJl'><tfoot id='0MHJl'></tfoot><dl id='0MHJl'><fieldset id='0MHJl'></fieldset></dl></div>

        DestroyJavaVM 线程总是在运行

        DestroyJavaVM thread ALWAYS running(DestroyJavaVM 线程总是在运行)

      1. <legend id='5PhaK'><style id='5PhaK'><dir id='5PhaK'><q id='5PhaK'></q></dir></style></legend>
          <i id='5PhaK'><tr id='5PhaK'><dt id='5PhaK'><q id='5PhaK'><span id='5PhaK'><b id='5PhaK'><form id='5PhaK'><ins id='5PhaK'></ins><ul id='5PhaK'></ul><sub id='5PhaK'></sub></form><legend id='5PhaK'></legend><bdo id='5PhaK'><pre id='5PhaK'><center id='5PhaK'></center></pre></bdo></b><th id='5PhaK'></th></span></q></dt></tr></i><div id='5PhaK'><tfoot id='5PhaK'></tfoot><dl id='5PhaK'><fieldset id='5PhaK'></fieldset></dl></div>

          <small id='5PhaK'></small><noframes id='5PhaK'>

          <tfoot id='5PhaK'></tfoot>
                <tbody id='5PhaK'></tbody>
                • <bdo id='5PhaK'></bdo><ul id='5PhaK'></ul>

                  本文介绍了DestroyJavaVM 线程总是在运行的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!

                  问题描述

                  在分析我的应用程序时,我遇到了一个奇怪的行为 - DestroyJavaVM 线程始终在运行 - 100% 的时间.

                  When profiling my application I came across a weird behavior - the DestroyJavaVM thread is ALWAYS running - 100% of the time.

                  在对该主题进行了一些研究之后,网上几乎没有任何有价值的信息,我所理解的只是这个线程应该卸载JVM 退出时.

                  After doing a little research on the subject, on which there's hardly any valuable information online, all I understood is that this thread is supposed to unload the JVM upon exit.

                  如果是这样,为什么从我启动应用程序的第一刻起,这个线程就 100% 处于 RUNNING 状态?它不会消耗宝贵的资源,因此可能会导致 OutOfMemoryError (就像我有时会得到的那样)?

                  If that's the case, why is this thread in RUNNING state 100% of the time from the very first moment I start my application? Doesn't it consume valuable resources and therefore may cause an OutOfMemoryError (like I sometimes get)?

                  对于这个线程实际做什么以及触发它的初始化有什么官方参考?

                  Is there any official reference to what this thread actually does and what triggers its initialization?

                  谢谢

                  推荐答案

                  这是因为大多数应用程序都是在线程中运行的.

                  This happens because most applications are run in threads.

                  所有 POJO 应用程序都从调用 main 方法开始.在最简单的情况下,此方法将完成所有工作,创建对象、调用方法等.一旦 main 完成,JVM 被告知使用 DestroyJavaVM 关闭线程等待所有 非守护线程在执行之前完成工作.这是为了确保您创建的任何非守护线程在 JVM 被拆除之前运行完成.

                  All POJO apps start by invoking the main method. In its most simple case, this method will do all of the work, creating objects, calling methods etc. Once main completes, the JVM is told to shut down using a DestroyJavaVM thread which waits for all non-daemon threads to complete before doing its work. This is to ensure that any non-daemon threads you create run to completion before the JVM is torn down.

                  但是,带有 GUI 的应用程序通常作为多个线程运行.一种用于监视系统事件,例如键盘或鼠标事件.一种用于维护窗口和显示等.这种应用程序的 main 方法可能只会启动所有必需的线程并退出.它仍然会创建 DestroyJavaVM 线程,但现在它所做的只是等待您创建的所有线程完成,然后再拆除 VM.

                  An app with a GUI, however, normally runs as a number of threads. One for watching for system events such as keyboard or mouse events. One for maintaining the windows and display etc. The main method of this kind of app will probably just start up all the required threads and exit. It still creates the DestroyJavaVM thread but now all that it does is wait for all of your created threads to finish before tearing down the VM.

                  因此,任何创建线程并仅依赖其功能的应用程序将始终有一个 DestroyJavaVM 线程等待它完成.由于它所做的只是join所有其他正在运行的线程,它不会消耗任何资源.

                  As a result, any app that creates threads and relies solely on their functionality will always have a DestroyJavaVM thread waiting for it to finish. Since all it is doing is joining all other running threads it does not consume any resources.

                  这篇关于DestroyJavaVM 线程总是在运行的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

                  本站部分内容来源互联网,如果有图片或者内容侵犯了您的权益,请联系我们,我们会在确认后第一时间进行删除!

                  相关文档推荐

                  Bytecode features not available in the Java language(Java 语言中不可用的字节码功能)
                  ClassCastException because of classloaders?(ClassCastException 因为类加载器?)
                  How can I add a Javaagent to a JVM without stopping the JVM?(如何在不停止 JVM 的情况下将 Javaagent 添加到 JVM?)
                  Cannot load 64-bit SWT libraries on 32-bit JVM ( replacing SWT file )(无法在 32 位 JVM 上加载 64 位 SWT 库(替换 SWT 文件))
                  Encourage the JVM to GC rather than grow the heap?(鼓励 JVM 进行 GC 而不是增加堆?)
                  Why a sawtooth shaped graph?(为什么是锯齿形图形?)
                    <bdo id='VUSCH'></bdo><ul id='VUSCH'></ul>

                          <tbody id='VUSCH'></tbody>

                        <i id='VUSCH'><tr id='VUSCH'><dt id='VUSCH'><q id='VUSCH'><span id='VUSCH'><b id='VUSCH'><form id='VUSCH'><ins id='VUSCH'></ins><ul id='VUSCH'></ul><sub id='VUSCH'></sub></form><legend id='VUSCH'></legend><bdo id='VUSCH'><pre id='VUSCH'><center id='VUSCH'></center></pre></bdo></b><th id='VUSCH'></th></span></q></dt></tr></i><div id='VUSCH'><tfoot id='VUSCH'></tfoot><dl id='VUSCH'><fieldset id='VUSCH'></fieldset></dl></div>
                          • <legend id='VUSCH'><style id='VUSCH'><dir id='VUSCH'><q id='VUSCH'></q></dir></style></legend>
                            <tfoot id='VUSCH'></tfoot>

                            <small id='VUSCH'></small><noframes id='VUSCH'>