草庐IT

CPU时间

全部标签

Java 分析 : detect which piece of code causes high CPU load

我使用JProfiler和YourKit分析了我的代码。但是,我一直无法弄清楚如何检测哪段代码导致高CPU负载。如果响应时间很差,检测热点是微不足道的。就我而言,虽然响应时间不是问题。只是在处理此特定请求的短时间内,CPU负载确实很高(高得惊人)。我如何确定是哪个类/方法导致了这个问题?我想我正在寻找的是某种列表,它告诉我处理一个方法所需的CPU周期数-左右。 最佳答案 CPU负载本质上表示cpu有事情要做的cpu周期数,而不仅仅是摆弄虚拟拇指。因此,如果您的请求确实在进行实际工作(而不是等待磁盘I/O),那么在工作完成时负载会变高

Android 获取设备的CPU型号和设备型号

原文:Android获取设备的CPU型号和设备型号-Stars-One的杂货小窝之前整的项目的总结信息,可能不太全,凑合着用吧,代码在最下面一节CPU型号数据华为:ro.mediatek.platformvivo:ro.vivo.product.platformoppo:ro.board.platform或ro.product.board三星:ro.board.platform小米:ro.soc.model小米:GKI2.0之前,/proc/cpuinfo中包含Hardware相关信息,应用可以从中读取cpu型号信息;GKI2.0之后,/proc/cpuinfo中不再包含Hardware相关信

java - 从 Java 内部 throttle CPU

我在这个(和其他)论坛上看到过许多标题相同的问题,但似乎没有一个能准确解决我的问题。就是这个:我有一个JVM,它占用了托管它的机器上的所有CPU。我想限制它,但是我不能依赖Java外部的任何限制工具/技术,因为我无法假设此Vm将在何处运行。因此,举例来说,我不能使用处理器关联,因为如果VM在Mac上运行,操作系统将不会使进程关联可用。我需要的是指示Java中是否存在确保线程不会占用全部CPU的方法。我想直截了本地指出,我不能像一些论坛中建议的那样使用基于交替执行和暂停的技术,因为线程需要连续生成值。理想情况下,我想要一些方法,例如,设置一些VM或线程优先级,或者以某种方式限制CPU消耗

java - 如何减少 Initializing Spring root WebApplicationContext 时间?

我知道这个问题太模糊了,任何人都无法提供解决方案,但如果需要,我可以提供更多详细信息。我的web应用程序正在使用spring,我已经将它部署到JBoss服务器,而jboss启动“初始化SpringrootWebApplicationContext”将近20分钟。我有什么选择可以减少这个吗?我在20个或更多xml文件中有近300个bean。请指教。 最佳答案 这里有一些Spring的最佳实践TIPS,将这些步骤与您的应用程序进行比较。https://developers.google.com/appengine/articles/sp

java - 根据使用 spring-boot @Scheduled 注释的条件动态修改调度程序时间

我有一个调度程序,它以5秒的固定延迟触发。我计划拥有多个调度程序,但现在,我们只使用一个调度程序。要求:应根据业务条件更改调度程序的fixedDelay。**例如,**默认fixedDelay为5秒,但它可以是6、8、10秒,具体取决于条件。因此,为了实现这一点,我正在尝试修改fixedDelay。但这对我不起作用。代码:接口(interface),带有延迟方法。publicabstractclassDynamicSchedule{/***Delaysscheduler*@parammilliseconds-thetimetodelayscheduler.*/abstractvoidd

java - Java 中创建字符串的时间

我正在为J2ME设备编写一个应用程序,并且非常关心不必要的字符串创建。由于使用字符串是内置的,即没有必要显式创建它们,我不确定我是否理解正确。例如,返回一个字符串(仅通过使用双引号)会在返回字符串时创建该字符串,即如果我有多个返回语句返回不同的字符串,则只会创建其中一个。是吗?此外,当使用字符串打印带有异常的消息时,如果不抛出异常,这些字符串永远不会被创建,对吧?很抱歉用这样的新手问题打扰您。 最佳答案 对于您目前收到的答复,我一点也不确定。如果您只是返回一个字符串文字,例如return"foo";然后将这些值嵌入到类文件中。JVM

java - 如果花费的时间太长则跳过函数

在Java中,我有一个以特定方式处理文本文件的函数。但是,如果花费太多时间,该过程很可能对该文本文件无用(无论是什么原因),我想跳过它。此外,如果该过程花费的时间太长,它也会使用过多的内存。我试过用这种方式解决它,但它不起作用:for(inti=0;idocs只是目录中文件的List。通常我必须手动停止代码,因为它“卡在”特定文件中(取决于该文件的内容)。有没有一种方法可以测量该函数调用的时间并告诉Java跳过该函数所用时间超过10秒的文件?编辑在拼凑了几个不同的答案后,我想出了这个效果很好的解决方案。也许其他人也可以使用这个想法。首先创建一个实现Runable的类(这样你可以在需要时

java - 在 O(log(N)) 时间内查找排序数组中一定范围内的整数数量的高效算法?

我遇到了一个必须在O(logn)中完成的面试题给定一个排序的整数数组和一个数字,找到数组中数字的开始和结束索引。Ex1:Array={0,0,2,3,3,3,3,4,7,7,9}andNumber=3-->Output={3,6}Ex2:Array={0,0,2,3,3,3,3,4,7,7,9}andNumber=5-->Output={-1,-1}我正试图为此找到一个有效的算法,但一直没有成功。 最佳答案 您可以使用二进制搜索的概念来查找开始和结束索引:要找到起始索引,将数组减半,如果值等于或大于输入数字,则重复数组的下半部分,否

java - 如果签名 jar 的证书(带有时间戳)过期会发生什么

我在2年前用时间戳签署了一个jar(小程序)。证书即将到期。会发生什么?是否会向用户发出警告,它会简单地工作吗?它会停止工作吗?我没有在小程序中添加任何特定代码来处理时间戳。我在签名时只包含了-tsaurl。编辑:它一直在工作。 最佳答案 在Java5SE之前,签名证书已过期的签名jar将不再有效或不可用。对于Java5SE和更高版本,签名证书过期的签名jar将继续工作。但是,过期的证书不能用于签署任何其他jar。FromOracle'sdocs:PriortoJ2SE5.0,thesignaturegeneratedbyjarsi

java - AWS/Lambda/Java 上的 Elasticsearch 客户端 - 2.5 秒客户端启动时间

我们使用AWSLambda(Java)和elasticsearch客户端连接到AWS上的托管elasticsearch实例。我在第一个请求上遇到了大约2.5秒的长时间等待(在冷启动之上)。之后它非常快。我真的无法弄清楚这种延迟是从哪里来的,我正在尝试对其进行优化。privatevoidtestPerformanceElasticSearch()throwsException{log.info("1.Beforetestingelasticsearchclient");AWS4Signersigner=newAWS4Signer();signer.setServiceName("es")