- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我是 G1 垃圾收集的新手,但我有一个最大为 26G 的堆,初始大小为 10G,当前大小为 26G,已使用 15G。
我使用以下参数打开了 GC 日志记录:
-XX:+PrintGC -XX:+PrintGCDetails -XX:+PrintGCTimeStamps -XX:+PrintGCDateStamps -XX:+PrintTenuringDistribution -verbose:gc -Xloggc:
当我查看我的垃圾回收日志时,我注意到我的 Ref Proc
似乎花费了最长的时间。我指定了 -XX:MaxGCPauseMillis=1000
,我的 GC 时间接近于此,但对我来说,Ref Proc
似乎仍然运行了很长时间。我想知道是否有办法减少这个时间?
我的 GC 日志摘录:
[GC pause (young)
Desired survivor size 335544320 bytes, new threshold 15 (max 15)
- age 1: 18542272 bytes, 18542272 total
- age 2: 1752016 bytes, 20294288 total
- age 3: 1083928 bytes, 21378216 total
- age 4: 1078592 bytes, 22456808 total
- age 5: 854640 bytes, 23311448 total
- age 6: 549048 bytes, 23860496 total
- age 7: 1372744 bytes, 25233240 total
- age 8: 623048 bytes, 25856288 total
- age 9: 909984 bytes, 26766272 total
- age 10: 930072 bytes, 27696344 total
- age 11: 928088 bytes, 28624432 total
- age 12: 1053440 bytes, 29677872 total
- age 13: 553512 bytes, 30231384 total
- age 14: 787592 bytes, 31018976 total
- age 15: 985216 bytes, 32004192 total
, 1.22150400 secs]
[Parallel Time: 176.4 ms]
[GC Worker Start (ms): 209376973.5 209376973.6 209376973.6 209376973.6 209376973.7 209376973.7 209376973.7 209376973.8 209376973.8 209376973.8 209376973.8 209376973.9 209376973.9 209376974.0 209376974.0 209376974.0 209376974.0 209376974.1 209376974.1 209376974.1 209376974.1 209376974.2 209376974.2
Avg: 209376973.9, Min: 209376973.5, Max: 209376974.2, Diff: 0.7]
[Ext Root Scanning (ms): 2.2 2.0 2.2 1.5 36.8 2.2 3.6 1.6 1.6 1.6 1.7 2.2 1.7 1.5 1.5 1.5 1.5 1.8 1.7 1.6 1.3 1.6 1.7
Avg: 3.3, Min: 1.3, Max: 36.8, Diff: 35.5]
[Update RS (ms): 13.4 14.0 13.2 14.1 0.0 13.2 12.0 13.7 14.1 13.7 13.7 13.0 13.6 13.7 14.0 13.8 13.7 13.2 13.5 13.8 13.8 13.3 13.3
Avg: 13.0, Min: 0.0, Max: 14.1, Diff: 14.1]
[Processed Buffers : 8 4 16 6 0 11 10 9 14 8 8 11 15 5 7 7 13 16 9 6 12 7 13
Sum: 215, Avg: 9, Min: 0, Max: 16, Diff: 16]
[Scan RS (ms): 0.3 0.0 0.4 0.0 0.2 0.3 0.2 0.3 0.0 0.3 0.3 0.3 0.3 0.2 0.0 0.3 0.3 0.4 0.2 0.0 0.3 0.3 0.3
Avg: 0.2, Min: 0.0, Max: 0.4, Diff: 0.3]
[Object Copy (ms): 151.2 150.7 151.0 150.9 130.3 151.0 150.9 150.3 151.0 150.5 151.5 150.5 151.2 151.6 151.5 151.0 151.4 150.8 150.2 150.3 151.2 150.2 151.3
Avg: 150.0, Min: 130.3, Max: 151.6, Diff: 21.2]
[Termination (ms): 4.5 4.8 4.7 4.9 4.2 4.7 4.7 5.4 4.6 5.2 4.2 5.2 4.5 4.1 4.1 4.6 4.2 4.8 5.5 5.2 4.5 5.5 4.4
Avg: 4.7, Min: 4.1, Max: 5.5, Diff: 1.4]
[Termination Attempts : 2171 2328 2294 2328 2003 2294 2274 2497 2232 2498 1970 2481 2191 2035 2006 2287 2007 2320 2640 2554 2243 2532 2216
Sum: 52401, Avg: 2278, Min: 1970, Max: 2640, Diff: 670]
[GC Worker End (ms): 209377145.9 209377145.2 209377145.8 209377145.5 209377145.3 209377145.8 209377145.9 209377145.7 209377145.8 209377145.2 209377145.4 209377145.6 209377145.2 209377145.2 209377145.2 209377145.8 209377145.9 209377145.4 209377145.7 209377145.6 209377145.2 209377145.6 209377146.0
Avg: 209377145.6, Min: 209377145.2, Max: 209377146.0, Diff: 0.9]
[GC Worker (ms): 172.4 171.6 172.2 171.9 171.7 172.1 172.2 171.9 172.0 171.3 171.5 171.8 171.3 171.2 171.2 171.9 171.9 171.4 171.6 171.5 171.0 171.4 171.8
Avg: 171.7, Min: 171.0, Max: 172.4, Diff: 1.3]
[GC Worker Other (ms): 4.8 4.8 4.8 4.9 4.9 4.9 4.9 5.0 5.0 5.1 5.1 5.1 5.2 5.2 5.2 5.2 5.3 5.3 5.3 5.4 5.4 5.4 5.5
Avg: 5.1, Min: 4.8, Max: 5.5, Diff: 0.7]
[Clear CT: 1.9 ms]
[Other: 1043.2 ms]
[Choose CSet: 0.1 ms]
[Ref Proc: 1029.7 ms]
[Ref Enq: 5.5 ms]
[Free CSet: 6.4 ms]
[Eden: 4660M(4660M)->0B(4680M) Survivors: 460M->440M Heap: 15178M(25600M)->10501M(25600M)]
[Times: user=4.98 sys=0.00, real=1.22 secs]
最佳答案
您的意思是,除了使用较少的弱/软引用之外?
如果你想要表现,我会尽量避免使用它们。您可以启用 -XX:+TraceReferenceGC
以获取有关您的引用的更多信息。
我经常建议人们尝试更大的 Eden 大小,并使用内存分析器来减少产生的垃圾量。由于从永久空间中清除了这么多东西,您似乎得到了很多过早的晋升。
关于java - G1 垃圾收集器在 Ref Proc 中花费大部分时间,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17853445/
我想读取帖子的数据并获取用户 key ,然后通过它进行搜索并同时获取用户数据,我尝试过,但它后退了一步,直到它才显示用户名我执行任何其他操作 这是帖子和经过身份验证的用户的 Firebase 实时数据
您知道是否有办法将 js ref 和 css ref 作为单个 ref 包含在 html 中?通常这些 ref 单独包含在 html head 中,但我的经理想知道下游消费者是否有一种简化的方法将这些
我正在使用 Swing+Clojure 开发一个 GUI 应用程序,它需要各种可变数据(例如滚动位置、用户数据、文件名、选定的工具选项等)。 我至少可以看到三种不同的处理这组数据的方式: 创建对所有数
我正在尝试通过 React 使用 ref 属性。我的浏览器出现奇怪的错误,但我无法弄清楚问题出在哪里。谁能向我解释一下为什么我会收到此错误: Error: Invariant Violation: a
在我的程序中,我有模板类,这些模板类主要是用于特殊目的 std::function 的包装器。最小的例子是: template class Foo { public: exp
如果被引用为参数的对象在函数中被修改,是否使用 ref 有关系吗?下面两个函数有区别吗? void DisposeObject(ClassThing c) { c.Dispose(); } vo
尝试将大型但线性的 svn 存储库迁移到 git。 svn 存储库没有标准布局(主干、分支、标签)...只有主干的一个目录。 Ubuntu 12.4 LTS,git 1.7.9.5。 $ git sv
您现在如何设置动态引用? 我收到一个错误 cannot set property of 'test' undefined ,如果我使用 this.someRef['test'] = ref;}/>
试图理解 gerrit 中的 refs/for/refs/* 功能。这个问题与 refs/for/master 无关。 我们什么时候可以使用这个 refs/for/refs/* 功能。 有人可以为此解
我以不同的方式调用 4 种方法时得到不同的结果: static void Main(string[] args) { var emp = new Employee { Name = "ABC"
假设我有以下内容: var t = typeof(Foo).MakeByRefType(); 有没有办法将结果转换回typeof(Foo)? 老实说,我发现的唯一方法是: var t = typeof
我以下列方式使用 ref。那么当在第 5 种方法中创建一个新对象时,是否会一直访问 main 方法中的原始 emp 并在那里创建一个新对象? 如果是,有没有一种方法可以实现相同的功能而无需多次迭代,即
我在文档的 html 标签内有一些文本。文字看起来像这样 I need this text <ref> Some unwanted text </ref> I need thi
一些背景: 前几天我遇到了一些事情,这让我开始思考嵌套函数调用中的重载解析。考虑以下代码: #include void printer(const int &a) { std::cout <<
如果直接从 this.refs 获取元素对象,那么为什么要使用 ReactDOM.findDOMNode? var HelloMessage = React.createClass({ click:f
我在这里做错了什么,或者从 C# 7.2 开始,不支持通过 ref 返回并允许设置的索引器? 作品: public ref byte this[int index] { get { r
看来我现在几乎每天都在这里问问题。我不确定这是好事还是坏事... 今天的“WTF flavor ”涉及我在使用来自 NI Measurement Studio 对象的函数时完全和完全无能为力。与我之前
这个问题在这里已经有了答案: Does foreach() iterate by reference? (10 个答案) Alternative to using ref in foreach? (
给定一个函数声明 dynamic DoSomething(dynamic inputObject) 我可以用枚举调用它作为inputObject: MyEnum myEnum; myEnum = Do
如果我将数组传递给函数并在函数内对数组进行更改,则函数外部存在的数组会反射(reflect)这些效果。例如: var myArr = [1, 2, 3]; function popAll(arr) {
我是一名优秀的程序员,十分优秀!