cpu緩存java
① 如何解決java佔用cpu100%
因為你用循環的時候就只有一條語句,能不佔90?
1 改一下這個循環的寫法
2 在循環語句加多一條或者兩條沒啥用的語句就行了。。。。
② java找不到高速緩存條目怎麼辦
java找不到高速緩存條目可以將這些數據緩存在存儲器中。java找不到高速緩存條目,可以每次操作時先在存儲器中查找緩存數據,可以直接使用或者將其獲取並放入緩存再使用。java是一門面向對象的編程語言。
③ java如何獲取cpu的一二三級緩存信息
可以利用jdk自帶的API獲取信息:(只支持jdk1.60以上的版本)
import java.io.InputStreamReader;
import java.io.LineNumberReader;
import java.util.ArrayList;
import java.util.List;
import mytools.com.sun.management.OperatingSystemMXBean;
import mytools.java.io.File;
import mytools.java.lang.management.ManagementFactory;
/**
* 獲取windows系統信息(CPU,內存,文件系統)
* @author libing
*
*/
public class WindowsInfoUtil {
private static final int CPUTIME = 500;
private static final int PERCENT = 100;
private static final int FAULTLENGTH = 10;
public static void main(String[] args) {
System.out.println(getCpuRatioForWindows());
System.out.println(getMemery());
System.out.println(getDisk());
}
//獲取內存使用率
public static String getMemery(){
OperatingSystemMXBean osmxb = (OperatingSystemMXBean) ManagementFactory.getOperatingSystemMXBean();
// 總的物理內存+虛擬內存
long totalvirtualMemory = osmxb.getTotalSwapSpaceSize();
// 剩餘的物理內存
long freePhysicalMemorySize = osmxb.getFreePhysicalMemorySize();
Double compare=(Double)(1-freePhysicalMemorySize*1.0/totalvirtualMemory)*100;
String str="內存已使用:"+compare.intValue()+"%";
return str;
}
//獲取文件系統使用率
public static List<String> getDisk() {
// 操作系統
List<String> list=new ArrayList<String>();
for (char c = 'A'; c <= 'Z'; c++) {
String dirName = c + ":/";
File win = new File(dirName);
if(win.exists()){
long total=(long)win.getTotalSpace();
long free=(long)win.getFreeSpace();
Double compare=(Double)(1-free*1.0/total)*100;
String str=c+":盤 已使用 "+compare.intValue()+"%";
list.add(str);
}
}
return list;
}
//獲得cpu使用率
public static String getCpuRatioForWindows() {
try {
String procCmd = System.getenv("windir") + "\\system32\\wbem\\wmic.exe process get Caption,CommandLine,KernelModeTime,ReadOperationCount,ThreadCount,UserModeTime,WriteOperationCount";
// 取進程信息
long[] c0 = readCpu(Runtime.getRuntime().exec(procCmd));
Thread.sleep(CPUTIME);
long[] c1 = readCpu(Runtime.getRuntime().exec(procCmd));
if (c0 != null && c1 != null) {
long idletime = c1[0] - c0[0];
long busytime = c1[1] - c0[1];
return "CPU使用率:"+Double.valueOf(PERCENT * (busytime)*1.0 / (busytime + idletime)).intValue()+"%";
} else {
return "CPU使用率:"+0+"%";
}
} catch (Exception ex) {
ex.printStackTrace();
return "CPU使用率:"+0+"%";
}
}
//讀取cpu相關信息
private static long[] readCpu(final Process proc) {
long[] retn = new long[2];
try {
proc.getOutputStream().close();
InputStreamReader ir = new InputStreamReader(proc.getInputStream());
LineNumberReader input = new LineNumberReader(ir);
String line = input.readLine();
if (line == null || line.length() < FAULTLENGTH) {
return null;
}
int capidx = line.indexOf("Caption");
int cmdidx = line.indexOf("CommandLine");
int rocidx = line.indexOf("ReadOperationCount");
int umtidx = line.indexOf("UserModeTime");
int kmtidx = line.indexOf("KernelModeTime");
int wocidx = line.indexOf("WriteOperationCount");
long idletime = 0;
long kneltime = 0;
long usertime = 0;
while ((line = input.readLine()) != null) {
if (line.length() < wocidx) {
continue;
}
// 欄位出現順序:Caption,CommandLine,KernelModeTime,ReadOperationCount,
// ThreadCount,UserModeTime,WriteOperation
String caption =substring(line, capidx, cmdidx - 1).trim();
String cmd = substring(line, cmdidx, kmtidx - 1).trim();
if (cmd.indexOf("wmic.exe") >= 0) {
continue;
}
String s1 = substring(line, kmtidx, rocidx - 1).trim();
String s2 = substring(line, umtidx, wocidx - 1).trim();
if (caption.equals("System Idle Process") || caption.equals("System")) {
if (s1.length() > 0)
idletime += Long.valueOf(s1).longValue();
if (s2.length() > 0)
idletime += Long.valueOf(s2).longValue();
continue;
}
if (s1.length() > 0)
kneltime += Long.valueOf(s1).longValue();
if (s2.length() > 0)
usertime += Long.valueOf(s2).longValue();
}
retn[0] = idletime;
retn[1] = kneltime + usertime;
return retn;
} catch (Exception ex) {
ex.printStackTrace();
} finally {
try {
proc.getInputStream().close();
} catch (Exception e) {
e.printStackTrace();
}
}
return null;
}
/**
* 由於String.subString對漢字處理存在問題(把一個漢字視為一個位元組),因此在 包含漢字的字元串時存在隱患,現調整如下:
* @param src 要截取的字元串
* @param start_idx 開始坐標(包括該坐標)
* @param end_idx 截止坐標(包括該坐標)
* @return
*/
private static String substring(String src, int start_idx, int end_idx) {
byte[] b = src.getBytes();
String tgt = "";
for (int i = start_idx; i <= end_idx; i++) {
tgt += (char) b[i];
}
return tgt;
}
}
④ 北大青鳥java培訓:Java內存模型原理
這篇文章主要介紹模型產生的問題背景,解決的問題,處理思路,相關實現規則,環環相扣,希望讀者看完這篇文章後能對Java內存模型體系產生一個相對清晰的理解,知其然知其所以然。
內存模型產生背景在介紹Java內存模型之前,java課程http://www.kmbdqn.cn/認為應該先了解一下物理計算機中的並發問題,理解這些問題可以搞清楚內存模型產生的背景。
物理機遇到的並發問題與虛擬機中的情況有不少相似之處,物理機的解決方案對虛擬機的實現有相當的參考意義。
物理機的並發問題硬體的效率問題計算機處理器處理絕大多數運行任務都不可能只靠處理器「計算」就能完成,處理器至少需要與內存交互,如讀取運算數據、存儲運算結果,這個I/O操作很難消除(無法僅靠寄存器完成所有運算任務)。
由於計算機的存儲設備與處理器的運算速度有幾個數量級的差距,為了避免處理器等待緩慢的內存完成讀寫操作,現代計算機系統通過加入一層讀寫速度盡可能接近處理器運算速度的高速緩存。
緩存作為內存和處理器之間的緩沖:將運算需要使用到的數據復制到緩存中,讓運算能快速運行,當運算結束後再從緩存同步回內存之中。
緩存一致性問題基於高速緩存的存儲系統交互很好的解決了處理器與內存速度的矛盾,但是也為計算機系統帶來更高的復雜度,因為引入了一個新問題:緩存一致性。
在多處理器的系統中(或者單處理器多核的系統),每個處理器(每個核)都有自己的高速緩存,而它們有共享同一主內存(MainMemory)。
當多個處理器的運算任務都涉及同一塊主內存區域時,將可能導致各自的緩存數據不一致。
為此,需要各個處理器訪問緩存時都遵循一些協議,在讀寫時要根據協議進行操作,來維護緩存的一致性。
⑤ 如何在Mac上清除Java高速緩存
如何在Mac上清除Java高速緩存?清除
Java
高速緩存可強制瀏覽器載入最新版本的
Java
小應用程序和應用程序。下面小編給大家帶來如何在Mac上清除
Java
高速緩存的詳細步驟:
1、單擊頂部的
Apple
圖標
2、單擊系統首選項圖標以打開
3、單擊位於其他部分下的
Java
圖標以打開
Java
控制面板
4、在
Java
控制面板中,單擊「Internet
臨時文件」下的設置
5、在「Internet
臨時文件」窗口中單擊刪除文件按鈕
6、這將打開刪除文件和應用程序窗口,單擊確定以確認刪除
⑥ Java程序CPU佔用過高怎麼解決
Java程序就是這樣的,我去年做了一個桌面軟體,也出現這樣的問題,後來不用java的自動垃圾回收,在必要的時候手動調用System.gc(),這種情況就很少出現了,但是偶爾也還有。另外,CPU佔用率過高的情況一般是編程的問題,重點考慮線程資源共享和網路流處理兩個方面,java大部分的高CPU佔用率都跟這兩點有關系。
