草庐IT

Java降低CPU使用率

问候-我们在工作中遇到了一些喜欢使用的疯子while(true){//Code}在他们的代码中。正如您可以想象的那样,这会最大限度地利用CPU。有谁知道降低CPU使用率以便其他人也可以使用服务器的方法。代码本身只是不断地轮询互联网以获取网站上的更新。因此我想稍微sleep的方法会大大降低CPU使用率。此外,所有操作都是在String对象(Java)中完成的,有人知道StringBuilder会减少多少开销吗?感谢指点 最佳答案 很多关于StringBuilder的“民间智慧”都是不正确的。例如,改变这个:Strings=s1+":"

java - 为什么我的线程程序只使用一个 CPU?

我有一个执行长时间计算的程序,所以我想加快它的性能。所以我现在尝试启动3个线程,但是java.exe仍然占用25%的CPU使用率(所以,只使用了一个CPU),即使我尝试使用它仍然存在>.setPriority(Thread.MAX_PRIORITY);并实时设置java.exe的优先级(24)。我尝试使用RealtimeThread但它似乎运行得更慢。如果每个线程分配给一个处理器就完美了,总CPU使用率提高到75%,但我不知道该怎么做。这就是我的代码现在的样子:Threadg1=newMyThread(i,j);g1.setPriority(Thread.MAX_PRIORITY);g

Java HotSpot(TM) 64 位服务器 VM 警告无法打开文件 logs/gc.log,因为没有这样的文件或目录

当我尝试运行时出现此错误RACK_ENV=testberailstesttest/system/service_provider_map_test.rb—seed48088JavaHotSpot(TM)64-BitServerVMwarning:Cannotopenfilelogs/gc.logduetoNosuchfileordirectory然后测试因这个错误而超时Timeoutwhilewaitingforclusterstatus[green]and[1]nodes/Users/patrickward/.rbenv/versions/2.4.1/lib/ruby/gems/2.

java - 非常慢的 Java full GC 挂钟

有时,在测试机器(Windows)上,Java完整GC需要超过20秒。GC日志显示real时间非常高,user也很高,但没有那么高(大约3秒)。在一种情况下,它是:21.2209796secs[Times:user=3.76sys=0.45,real=21.22secs]可能是什么原因?我有一个怀疑,但现在不想说。找出根本原因的最简单方法是什么?如果您不了解Windows但了解Linux,那也是一种选择:可以在Linux上重新运行测试。流程是这样开始的:"%JAVA_HOME%\bin\java.exe"-verbose:gc-XX:+PrintGCDetails-XX:+PrintG

java - 如何解释导致 OutOfMemoryError 的 G1 GC 日志?

我想知道是否有人能够向我解释如何解释导致OutOfMemoryError的一些G1GC日志?我知道堆转储是找出实际使用堆的最佳选择,但我无法获取它,因为它包含无法离开客户端站点的protected信息。我只有应用程序日志(包括来自OOME的堆栈)和G1GC日志。完整的G1GC日志包含很多细节,因此除非有人特别需要查看它们,否则我不会将它们放在这里。这些来自的特定Java版本是:>java-versionjavaversion"1.7.0_21"Java(TM)SERuntimeEnvironment(build1.7.0_21-b11)JavaHotSpot(TM)64-BitServ

java - GC 和 FontData 获取字体高度有什么区别?

这解释了字体指标我认为我们可以像这样在SWT中获得“字体高度”;GCgc=newGC(label);System.out.println(gc.textExtent(label.getText()));System.out.println(label.getFont().getFontData()[0].getHeight());为什么这两个出局不一样?哪个是字符串的正确高度? 最佳答案 GC#textExtent()以像素返回范围,而FontData以点返回字体。这里的单位不同。 关于

java - Spring 数据 JPA OutOfMemoryError : GC overhead limit exceeded

我正在开发一个包含大量实体(3072)的应用程序。我们使用jhipster作为项目结构。到目前为止一切正常,直到我们想将SpringBoot版本从1.3.2(1.9.2spring-data-jpa)升级到当前的1.5.1(spring-data-jpa1.11.0)我在启动时遇到异常.提供更多内存、堆大小等没有帮助。我认为问题在某种程度上与1.10.X之后的spring-data-jpa有关,因为我们在spring-data-jpa1.9.x中没有这样的问题Causedby:org.springframework.beans.factory.UnsatisfiedDependency

java - 为什么并发 GC 需要 remark 阶段

并发GC需要remark阶段。remarkphase的作用是在concurrentmarkphase中标记被修改的对象。但我认为如果我们只在concurrentmarkphase标记新创建的对象,就没有必要执行remarkphase。remarkphase是因为对象被修改了。修改可以是两种类型。一个是创建新对象,另一个是修改指向另一个对象的指针。如果我们标记新创建的对象,就可以轻松解决新对象问题。而修改指向另一个对象的指针实际上不是问题。因为Deadobjectcannotrevive死对象意味着没有人可以指向该对象。他们如何复活?所以修改后的指针应该指向已经标记好的对象。这意味着不需

java - JVM 的 GC 事件的编程通知

我想跟踪在GC上花费了多少时间以及收集了多少内存,但不是通过分析GC日志(即分析我从-XX:+PrintGCWhatever得到的)。我发现我可以使用Sun的ManagementFactory获得一个GarbageCollectorMXBean,它可以给我一些包含内存信息的GCInfo对象,但我不能保证我可以通过这种方式收集所有GC。有人知道在代码中执行此操作的方法吗? 最佳答案 GarbageCollectorMXBean是我能在SunJVM上找到的最好的。根据我的经验,它实际上非常接近您的要求。我想您可以有一个专用线程,它会不时

java - 单 Java 线程运行时的双核 CPU 利用率

这个问题在这里已经有了答案:关闭10年前。PossibleDuplicate:WouldamultithreadedJavaapplicationexploitamulti-coremachineverywell?我的双核机器(WindowsXP32位环境)上有一个像这样的简单Java线程运行publicstaticvoidmain(String[]strs){longj=0;for(longi=0;i我的期望是它会坚持使用单个CPU来充分利用高速缓存(因为在循环中我们一直使用局部变量j,因此一个CPU利用率将是100%,而另一个几乎是虚度。令我惊讶的是,线程启动后,两个CPU的利用率