1. java參數中的分配cpu
應該是沒有的,cpu針對java沒有影響吧,他只是去分配內存的位置及大小空間
2. java的多線程和多CPU之間的關系
jvm自動分配線程到os,os自動分配線程到CPU
3. java佔用cpu高
java進程佔用CPU過高常見的兩種情況:
1,代碼中有死循環或者接近死循環的操作
2,快速創建大量臨時變數,導致頻繁觸發gc回收
4. 如何讓java更好的利用多cpu
幾個意見大致如下,第一,不能,因為「進程是CPU進行調度的單位,而JVM是一個進程,於是就只能跑在一個CPU上」。第二,「進程是CPU進行調度的單位,這沒錯,但是OS負責將一個進程在不同的CPU上調度到另外一個CPU上,而這個進程,則是由不同的線程構成的,那麼說,線程還是在不同的CPU上運行了」。我更傾向於第二種解釋,於是核心問題就變成了討論「JVM能不能夠將線程安排到不同的CPU上去運行呢?」。
最終,在SUN公司授權的《Java核心技術》,第7版卷II,第8版卷I,有關於「可運行線程」中,找到如下兩句話:
「今天,人們很可能有單台擁有多個CPU的計算機,但是,並發執行的進程數並不是CPU數目制約的。操作系統的時間片分配給每一個進程,給人並行處理的感覺」。
好吧,上面的這句話,並不能說明這個答案,但是當我看到下面的這句原話的時候,感覺答案就在這里了:
"在具有多個處理器的機器上,每一個處理器運行一個線程,可以有多個線程並行運行。當然,如果線程的數目多於處理器的數目,調度器依然採用時間片機制"。這句話足以用來反駁那個出問題的人了,因為他的答案本身就是錯的。
盡管,盡信書不如無書,但是,還能有更好的選擇么?帶著這個問題,繼續走下去~ Fighting~ [email protected] I enjoy PM、Java、Oracle. I'm an English lover as well~ ho ho~
後記:
更詳細的信息可以參見有關Java虛擬機實現的「並發」系列講解,基本上每本關於Java虛擬機有關的書籍以及官方文檔都會講到JVM如何實現線程的幾種方式。 基於系統內核,基於用戶線程等等實現。JVM中的線程實現是本地化的~ 本地化的意思就是與平台有關了,盡管與平台有關,但是線程調度,仍舊是最佳高效的方式,有資料曾說過:線程的創建銷毀與調度的開銷是進程的三十分之一。
5. Java如何獲取CPU標識符
可嘗試通過System.getProperties() 這類API獲取:
System.getProperty("os.arch") -- cpu架構 ,如x86
os.name --如Windows XP
os.version -- 操作系統版本號
如果還無法滿足,可以根據系統的不同,利用Runtime入口去執行命令來獲取,比如:
linux 下 可以執行如:
Runtime.getRuntime().exec("cat /proc/cpuinfo |grep vender_id");
之類的語句進行獲取
6. java耗cpu的代碼
應該是可以消耗CPU的一些代碼,這樣話能搞這些小孩兒也將化作,應該表明身份應該配上風格還非常的。
7. JAVA開發電腦額cpu的選擇
java開發對機器要求也不高,基本主流配置的都夠用的。cpu為主,內存現在很便宜,8G或者16G也沒多少錢。固態硬碟也不貴,買個做系統盤,數據最好還是存在普通硬碟上。
8. Java如何讀取CPU的數據信息
java獲取所有系統信息(CPU、內存、進程等)的代碼:
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;
}
}
9. java 怎麼查看伺服器的CPU使用率
1、確定當前系統安裝的jdk是1.6版本以上
2、windows系統中有獲取cpu使用率的可執行文件exe,只要在java中獲取該文件的執行路徑,通過Java調用即可。
3、獲取操作系統可執行文件目錄procCmd
4、調用java的Runtime.getRuntime().exec執行cmd應用程序
5、利用java中sleep來計算睡眠前後cpu的忙碌時間與空閑時間,因為sleep不會釋放系統資源
6、根據忙碌時間占總時間的比例來計算cpu使用率!
10. java能利用多核cpu嗎
java線程可以在運行在多個cpu核上。
"在具有多個處理器的機器上,每一個處理器運行一個線程,可以有多個線程並行運行。當然,如果線程的數目多於處理器的數目,調度器依然採用時間片機制"。
現代os都將線程作為最小調度單位,進程作為資源分配的最小單位。 在windows中進程是不活動的,
只是作為線程的容器。
也就是說,java中的所有線程確實在JVM進程中,但是CPU調度的是進程中的線程。
"在具有多個處理器的機器上,每一個處理器運行一個線程,可以有多個線程並行運行。當然,如果線程的數目多於處理器的數目,調度器依然採用時間片機制"。這句話足以用來反駁那個出問題的人了,因為他的答案本身就是錯的。
更詳細的信息可以參見有關Java虛擬機實現的「並發」系列講解,基本上每本關於Java虛擬機有關的書籍以及官方文檔都會講到JVM如何實現線程的幾種方式。 基於系統內核,基於用戶線程等等實現。JVM中的線程實現是本地化的~ 本地化的意思就是與平台有關了,盡管與平台有關,但是線程調度,仍舊是最佳高效的方式,有資料曾說過:線程的創建銷毀與調度的開銷是進程的三十分之一。