- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在开发一个应用程序,其目的是尽可能快地计算报告。
我的应用程序使用了大量内存;超过 100 个 Go。
自上次发布以来,我注意到性能大幅下降。我的调查显示,在计算过程中,我在 40 到 60 秒之间进行了多次垃圾回收!!!(JMC 告诉我它们是 SerialOld 但我不知道它到底是什么意思) 当然,当 JVM 进行垃圾收集时,应用程序会完全卡住
我现在正在调查这些垃圾收集的来源......这是一项非常艰苦的工作。
我怀疑,如果这些垃圾回收这么长,那是因为它们在 finalize
函数中花费了很多时间 (我知道,在我们从其他团队集成的所有库中,其中一些使用终结器)
但是,我不知道如何确认(或不确认)这个假设;如何找到哪个终结器很耗时。
我正在寻找一个好的工具,甚至是一个好的方法论
Here is data collected via JVisualVM
As you can see, I always have many "Pending Finalizers" when I have a log Old Garbage
What is surprising is that when I am using JVisualVM, the above graph scrolls regularly from right to left. When the Old Garbage is triggered, the scrolling stops (until here, it looks normal, this is end-of-world). However, when the scrolling suddenly restart, it does not from the end of Old Garbage but from the end of Pending Serializer
This lets me think that the finalizers were blocking the JVM
Does anyone has an explaination for this?
非常感谢菲利普
最佳答案
My application uses a big amount of memory; more than 100 Go.
JMC tells me that they are SerialOld but I don't know what it exactly means
如果您将串行收集器用于 100GB 的堆,那么长时间停顿是意料之中的,因为串行收集器是单线程的,一个内核每单位时间只能消耗这么多内存。
简单地选择任何一个多线程收集器应该会产生更短的暂停时间。
However, I don't know how to confrim (or not) this hypothesis; How to find which finalizer is time consuming.
通常:收集更多数据。对于与 GC 相关的事情,您需要启用 GC 日志记录,对于花在 Java 代码(无论是您的应用程序还是第 3 方库)上的时间,您需要一个分析器。
关于java - 如何找到哪个Finalizer耗时,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40562665/
关闭。这个问题需要更多 focused .它目前不接受答案。 想要改进这个问题吗? 更新问题,使其只关注一个问题 editing this post . 关闭 2 年前。 Improve this q
1.final final修饰类,说明这个类不能被继承,是以个顶级类。 final修饰变量,说明这个变量是常量。 final修饰方法,表示这个方法不能被重写,不过可以冲在final方法。 比如有个
我喜欢使用 -Wsuggest-final-types 编译我的代码和 -Wsuggest-final-methods以便在可能使用 final 关键字以允许编译器更积极地优化的机会时收到警告。 不过
我在 Java 8 中有一个异步操作,它返回一个 onError 回调或一个 onSuccess 回调。如果操作成功与否,我需要在我的方法内部返回。所以我返回一个 boolean 值来说明这个信息。我
我正在阅读一些内容,需要对最终类和方法进行一些说明。我的理解是,将一个类声明为 final 会阻止该类被扩展。因此,是否有必要将最终类中的方法声明为最终的?在我看来,如果类不能扩展,则没有必要将方法声
有什么区别 try { // action A } catch(Exception e) { // action B } finally { // action C }
这个程序是我类(class)的最终作业,我无法弄清楚为什么我收到错误“从内部类引用的局部变量必须是最终的或有效的最终”。该程序正在运行并发线程来对# 数组进行排序,然后找到该数组的高值和低值。当我在没
C++11 added final. 终于! 我了解 final 做了两件事: 使类不可继承。 使类中的(虚拟)函数不可覆盖(在派生类中)。 这两者似乎是相互独立的。但以以下为例: class Foo
我想使用具有多个提交按钮的react-final-form构建表单,其中每个提交按钮在表单中设置不同的值。本质上,我想创建一个在呈现的HTML中看起来像这样的表单: Are you over 1
我想知道什么时候应该对变量和(或)方法使用静态、最终、静态最终参数。据我了解: final:类似于c++中的const参数。它基本上意味着值(或在方法中 - 返回值)不会改变。 静态:这意味着值(或方
我正在做一个编程类(class)项目,用于 400 行矩阵本身的矩阵乘法。我让它以顺序模式工作,该项目的目标是编写并行实现。 我有以下代码,当然,当我尝试引用内部类中的计数器 j 时,我收到一个关于
也许这是简单的问题,但我找不到答案。 声明为final的经典变量是否包含与非final变量不同的内存段? 最佳答案 我想说,谈到局部变量,基于 this answer 是不行的。 : The trut
考虑以下代码: #include class B { virtual void f() { std::cout << "Base" << '\n'; } }; class D
这个问题已经有答案了: java: Is it possible to set a lambda expression for an array of Buttons is a for loop? I
考虑这个代码片段 public class ConstantFolding { static final int number1 = 5; static final int numbe
我确定在内部类中访问的变量应该声明为final 或有效final。但在下面的情况下我很困惑。不知道是不是我理解错了。 public class MyClass { private boolea
我必须将一个 java.sql.Connection 对象传递给一个匿名内部类,这意味着我必须对它进行 final 引用。但是,我担心任何资源泄漏。 public static String foo(
我收到 SonarQube 错误:“强烈建议在此方法实现结束时调用 super.finalize(),以防父实现也必须释放一些系统资源。” 但我发现 Object 类没有实现 finalize方法。
我一般认为资源清理是在 finally block 中完成的, 最近我在一个类中发现了这个特定的代码片段,它覆盖了 Object 类'finalize()方法。 protected void fina
让我们在父类中使用这个方法: public void calculateSum(int a, final int b) { } 子类有: public void calculateSum(int a,
我是一名优秀的程序员,十分优秀!