草庐IT

gc_collect_cycles

全部标签

java - 我可以使用 Collection.size() 来替换这段代码中的计数器吗?

代码如下:publicclassLogService{privatefinalBlockingQueuequeue;privatefinalLoggerThreadloggerThread;privatefinalPrintWriterwriter;@GuardedBy("this")privatebooleanisShutdown;@GuardedBy("this")privateintreservations;//这是JavaConcurrencyinPractice一书的片段,我在想也许计数器reservations是不必要的,因为我们可以简单地使用queue.size()获取q

Java 垃圾收集器 G1GC 花费很长时间等待 'Object Copy'(疏散暂停)

我不是Java新手,但我对垃圾回收知之甚少。现在我想通过一些实际经验来改变这种状况。我的目标是延迟时间低于0.3秒,或者在极端情况下0.5秒也可以。我有一个带有-Xmx50gb(-Xms50gb)的应用程序并设置了以下其他GC选项:-XX:+UseG1GC-Xloggc:somewhere.gc.log-XX:+PrintGCDateStamps但现在我偶尔会因为垃圾收集而暂停超过5秒,尽管似乎有足够的可用内存。我发现的一个原因:[GCpause(G1EvacuationPause)(young)42G->40G(48G),5.9409662secs]为什么GCG1还在为此做一个“停止

java - 如何通过查看 gc 日志查看正在运行的垃圾收集器?

如何通过查看次要和主要收集的gc日志来了解正在运行的垃圾收集器(CMS、并行等)?我无权访问设置为java的命令行选项(appserver的sysadm不会让我看到它们)。我确实有相当详细的gc日志。 最佳答案 GC消息的确切格式取决于JVM版本和JVM设置。您可以在OracletutorialaboutGCtuning查看sample.DefNew是默认收集器。它是串行的还是并行的,选择哪一个取决于JVM版本/设置。您可以使用java-XX:+PrintCommandLineFlags-version查看JDK6中的默认设置。在我

java - 如何确定应用程序中的 gc-cpu 利用率?

我们希望将JConsole/JVisualVM的一些功能内部化,并从正在运行的应用程序中收集有关cpu利用率和内存消耗的数据。原因是,安全约束阻止我们在生产系统上向外部开放jmx端口。所需的大部分数据都可以通过MXBeans进行监控,但是,用于垃圾收集的cputime仍然让我们望而却步。通过GarbageCollectorMXBean监控gc-time没有用,因为它只提供并行工作收集器的walltime。我假设可以使用ThreadMXBean来确定所有gc线程的cputime。我看不出有什么办法可以安全地识别这些线程。有人知道JVisualVM是如何计算这个数字的吗?

java - 我可以通过编程方式找出实例所在的 GC 代吗?

此问题的范围仅限于HotSpotgenerations.有没有办法以编程方式找出特定实例生活在哪一代。数据如:年轻一代还是老一代?如果年轻,哪个幸存者空间?在TLAB内部?哪个线程?任何技术(例如,BTrace、JVMTI)都可以工作,只要我能做这样的事情:Objectx=newObject();HotSpotGenerationInfoinfo=HotSpotGenerationUtil.getInfo(x);乞丐不能成为选择者,但理想情况下,我还可以了解感兴趣的实例何时从一代转移到另一代在它发生的那一刻(即,基于事件回调-不感兴趣在轮询中隐含的延迟和开销。)对没有理由就说“不”的答

java - 垃圾收集详细信息 : Is this object eligible for GC?

我想像这样的程序...classTest{publicstaticvoidmain(String[]args){newTest();System.out.println("done");}protectedvoidfinalize(){System.out.println("thisobjectisknowntoneverbereferenced.");}}...可能会在“完成”之前输出"thisobjectisknowntoneverbereferenced."。(如果我在这里错了,请纠正我!)此外,编译器/JVM很容易检测到“未读的局部变量”。例如,在下面的程序中,Eclipse注

java - 为什么这么多方法使用 Collection 而不是 Iterable?

有了C#,我逐渐爱上了IEnumerable界面。在很多情况下,这就是您想要提供和接受的全部内容。此外,它在.Net库中也很有用。例如,您在List上有一个构造函数需要IEnumerable的类(class).我现在必须使用Java,自然想使用等效的Iterable界面。但是,似乎我真的不能在任何地方使用它。一切似乎都在使用扩展的Collection接口(interface)代替。为什么是这样?例如,您有ArrayList采用Collection的构造函数:Constructsalistcontainingtheelementsofthespecifiedcollection,inth

java - 为什么 GC 每小时运行一次?

我们观察到完整垃圾回收(GC)通常每小时执行一次。检查了JreMemoryLeakPreventionListener的时间间隔。它被设置为Long.MAX_VALUE。尽管gc每小时运行一次。还观察到GC称为hourlybasis是显式GCGC日志:2016-10-15T23:23:09.341-0400:165558.099:[GC(System.gc())[PSYoungGen:264601K->5865K(1357312K)]389672K->130937K(4153856K),0.0075210secs][Times:user=0.07sys=0.00,real=0.00se

java - Guava/Google Collections 的向后兼容性如何?

我正在开发包含多个项目的大型应用程序,所有项目仍然使用GoogleCollections1.0。我想升级到Guava12。项目的测试覆盖率不是很好。有没有人有过类似的升级经验,有没有不兼容的地方?主要问题是什么? 最佳答案 这里是Guava贡献者。Guava12几乎完全向后兼容GoogleCollections,但极少数方法已经过了18个月的弃用期并被删除;见https://code.google.com/p/guava-libraries/issues/detail?id=836.也就是说,没有人应该仍然在使用GoogleColl

java - 如何让 Label 在 SWT 中继承 Composite GC

我正在编写一个应用程序,我们的设计师想要对我们的一些合成Material的某些背景使用渐变。我写了下面的代码:composite.addListener(SWT.Paint,newListener(){publicvoidhandleEvent(Evente){GCgc=e.gc;Rectanglerect=composite.getClientArea();Colorcolor1=newColor(display,0,0,0);Colorcolor2=newColor(display,255,255,255);gc.setForeground(color1);gc.setBackgr