本文整理匯總了Java中java.lang.management.ManagementFactory.getThreadMXBean方法的典型用法代碼示例。如果您正苦於以下問題:Java ManagementFactory.getThreadMXBean方法的具體用法?Java ManagementFactory.getThreadMXBean怎麽用?Java ManagementFactory.getThreadMXBean使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類java.lang.management.ManagementFactory
的用法示例。
在下文中一共展示了ManagementFactory.getThreadMXBean方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。
示例1: call
import java.lang.management.ManagementFactory; //導入方法依賴的package包/類
@Override
public String call() {
Map<String, String> memoryMap = new HashMap<>();
OperatingSystemMXBean osMxBean = ManagementFactory.getOperatingSystemMXBean();
double cpu = osMxBean.getSystemLoadAverage();
memoryMap.put("cpuLoad", String.format(doubleStringFormatter, round(cpu, doubleRoundPlaces)));
ThreadMXBean threadmxBean = ManagementFactory.getThreadMXBean();
int threadCount = threadmxBean.getThreadCount();
memoryMap.put("cpuRunningThreads", String.valueOf(threadCount));
MemoryMXBean memBean = ManagementFactory.getMemoryMXBean();
MemoryUsage memHeapUsage = memBean.getHeapMemoryUsage();
MemoryUsage nonHeapUsage = memBean.getNonHeapMemoryUsage();
memoryMap.put("heapInit", String.valueOf(memHeapUsage.getInit()));
memoryMap.put("heapMax", String.valueOf(memHeapUsage.getMax()));
memoryMap.put("heapCommit", String.valueOf(memHeapUsage.getCommitted()));
memoryMap.put("heapUsed", String.valueOf(memHeapUsage.getUsed()));
memoryMap.put("nonHeapInit", String.valueOf(nonHeapUsage.getInit()));
memoryMap.put("nonHeapMax", String.valueOf(nonHeapUsage.getMax()));
memoryMap.put("nonHeapCommit", String.valueOf(nonHeapUsage.getCommitted()));
memoryMap.put("nonHeapUsed", String.valueOf(nonHeapUsage.getUsed()));
return memoryMap.toString();
}
示例2: getAllThreadIDsExceptMain
import java.lang.management.ManagementFactory; //導入方法依賴的package包/類
/**
* @return Set of the IDs of all threads that are started except the "main" thread.
*/
public Set<Long> getAllThreadIDsExceptMain() {
ThreadMXBean thbean = ManagementFactory.getThreadMXBean();
// get the IDs of all live threads.
long[] threadIDs = thbean.getAllThreadIds();
Set<Long> res = new HashSet<Long>();
// get the IDs of all threads except main
for (long id : threadIDs) {
Thread t = getThread(id);
if (t != null && !"main".equals(t.getName())) {
res.add(id);
}
}
return res;
}
示例3: buildDeadlockInfo
import java.lang.management.ManagementFactory; //導入方法依賴的package包/類
static String buildDeadlockInfo() {
ThreadMXBean threadBean = ManagementFactory.getThreadMXBean();
long[] threadIds = threadBean.findMonitorDeadlockedThreads();
if (threadIds != null && threadIds.length > 0) {
StringWriter stringWriter = new StringWriter();
PrintWriter out = new PrintWriter(stringWriter);
ThreadInfo[] infos = threadBean.getThreadInfo(threadIds, true, true);
for (ThreadInfo ti : infos) {
printThreadInfo(ti, out);
printLockInfo(ti.getLockedSynchronizers(), out);
out.println();
}
out.close();
return stringWriter.toString();
} else {
return null;
}
}
示例4: countTimerThreads
import java.lang.management.ManagementFactory; //導入方法依賴的package包/類
private static int countTimerThreads() {
ThreadMXBean threadBean = ManagementFactory.getThreadMXBean();
int count = 0;
ThreadInfo[] infos = threadBean.getThreadInfo(threadBean.getAllThreadIds(), 20);
for (ThreadInfo info : infos) {
if (info == null) continue;
for (StackTraceElement elem : info.getStackTrace()) {
if (elem.getClassName().contains("Timer")) {
count++;
break;
}
}
}
return count;
}
示例5: testReset
import java.lang.management.ManagementFactory; //導入方法依賴的package包/類
@Test
public void testReset() {
System.out.println("reset");
ThreadMXBean tbean = ManagementFactory.getThreadMXBean();
addStacktrace(tbean.getThreadInfo(tbean.getAllThreadIds(), Integer.MAX_VALUE), System.nanoTime());
addStacktrace(tbean.getThreadInfo(tbean.getAllThreadIds(), Integer.MAX_VALUE), System.nanoTime());
instance.reset();
assertTrue(instance.methodInfos.size()-1 == 0);
assertTrue(instance.threadIds.size() == 0);
assertTrue(instance.threadNames.size() == 0);
assertEquals(-1L, instance.currentDumpTimeStamp);
//assertEquals(-1L, instance.firstDumpTimeStamp);
assertEquals(0, instance.stackTraceCount);
try {
instance.createSnapshot(System.currentTimeMillis());
fail();
} catch (CPUResultsSnapshot.NoDataAvailableException ex) {
}
}
示例6: getAllThreads
import java.lang.management.ManagementFactory; //導入方法依賴的package包/類
/**
* @return a list of all threads started in the JVM.
*/
public List<Thread> getAllThreads() {
final ThreadGroup root = getRootThreadGroup();
final ThreadMXBean thbean = ManagementFactory.getThreadMXBean();
// get the number of all live threads
int nAlloc = thbean.getThreadCount();
int n = 0;
Thread[] threads;
do {
nAlloc *= 2; // increase the size since more threads may have been created
threads = new Thread[nAlloc];
n = root.enumerate(threads, true); // get all active threads from this thread group
} while (n == nAlloc); // stop if all active threads are enumerated
List<Thread> res = new ArrayList<Thread>();
for (Thread th : threads) {
res.add(th);
}
return res;
}
示例7: dumpTestThreads
import java.lang.management.ManagementFactory; //導入方法依賴的package包/類
/**
* A debugging tool to print stack traces of most threads, as jstack does.
* Uninteresting threads are filtered out.
*/
static void dumpTestThreads() {
ThreadMXBean threadMXBean = ManagementFactory.getThreadMXBean();
System.err.println("------ stacktrace dump start ------");
for (ThreadInfo info : threadMXBean.dumpAllThreads(true, true)) {
String name = info.getThreadName();
if ("Signal Dispatcher".equals(name))
continue;
if ("Reference Handler".equals(name)
&& info.getLockName().startsWith("java.lang.ref.Reference$Lock"))
continue;
if ("Finalizer".equals(name)
&& info.getLockName().startsWith("java.lang.ref.ReferenceQueue$Lock"))
continue;
System.err.print(info);
}
System.err.println("------ stacktrace dump end ------");
}
示例8: main
import java.lang.management.ManagementFactory; //導入方法依賴的package包/類
public static void main(String[] args) throws Exception {
long value = mbean.getInternalThreadCount();
if (value < MIN_VALUE_FOR_PASS || value > MAX_VALUE_FOR_PASS) {
throw new RuntimeException("Internal thread count " +
"illegal value: " + value + " " +
"(MIN = " + MIN_VALUE_FOR_PASS + "; " +
"MAX = " + MAX_VALUE_FOR_PASS + ")");
}
System.out.println("Internal Thread Count = " + value);
ThreadMXBean thread =
ManagementFactory.getThreadMXBean();
if (!thread.isThreadCpuTimeSupported()) {
System.out.println("Thread Cpu Time is not supported.");
return;
}
while(!testCPUTime()) {
Thread.sleep(100);
}
}
示例9: countThreads
import java.lang.management.ManagementFactory; //導入方法依賴的package包/類
/**
* Count the number of threads that have a stack frame containing
* the given string
*/
protected static int countThreads(String search) {
ThreadMXBean threadBean = ManagementFactory.getThreadMXBean();
int count = 0;
ThreadInfo[] infos = threadBean.getThreadInfo(threadBean.getAllThreadIds(), 20);
for (ThreadInfo info : infos) {
if (info == null) continue;
for (StackTraceElement elem : info.getStackTrace()) {
if (elem.getClassName().contains(search)) {
count++;
break;
}
}
}
return count;
}
示例10: dump
import java.lang.management.ManagementFactory; //導入方法依賴的package包/類
public static ThreadInfo[] dump(int maxDepth,boolean onlyDeadLock){
ThreadMXBean threadBean = ManagementFactory.getThreadMXBean();
long[] ids ;
if(onlyDeadLock) {
ids = threadBean.findDeadlockedThreads();
}else {
ids = threadBean.getAllThreadIds();
}
if(ids !=null) {
return threadBean.getThreadInfo(ids, maxDepth);
}
else {
return null;
}
}
示例11: getTimedByteLimitedHandler
import java.lang.management.ManagementFactory; //導入方法依賴的package包/類
/**
* Initialization of the pseudo packet handler which measures the time to handle the configured amount of bytes.
*
* @param pcap the interface with the pcap library needed to construct the packet handler.
* @param MAX_BYTES the maximum amount of bytes captured
* @return the handler for the packets.
*/
private static PcapPacketHandler<PseudoPacketHandler> getTimedByteLimitedHandler(final Pcap pcap, final long MAX_BYTES) {
// Packet handler. Generic callback function for PseudoPacketHandler.
return new PcapPacketHandler<PseudoPacketHandler>() {
boolean started = false;
long packetBytes = 0;
long startTime;
long stopTime;
// A timer for performance tests.
final ThreadMXBean threadMXBean = ManagementFactory.getThreadMXBean();
// Handle nextPacket callback.
public void nextPacket(PcapPacket packet, PseudoPacketHandler handler) {
if (!started) {
startTime = threadMXBean.getCurrentThreadCpuTime();
logger.info("Started at "+ startTime);
started = true;
}
handler.handle(packet);
packetBytes+= packet.size();
if (packetBytes >= MAX_BYTES) {
stopTime = threadMXBean.getCurrentThreadCpuTime();
pcap.breakloop();
logger.info("Stopped after " + ((stopTime - startTime)/10000000000.0) + " seconds and " + packetBytes + " bytes.");
}
}
};
}
示例12: thePathOfFifteenThousandJumps
import java.lang.management.ManagementFactory; //導入方法依賴的package包/類
@Test
public void thePathOfFifteenThousandJumps() {
byte[] bytecode = new byte[15000 * 6 + 3];
int k = 0;
while (k < 15000 * 6) {
int target = k + 6;
bytecode[k++] = 0x5b; // JUMPDEST
bytecode[k++] = 0x62; // PUSH3
bytecode[k++] = (byte)(target >> 16);
bytecode[k++] = (byte)(target >> 8);
bytecode[k++] = (byte)(target & 0xff);
bytecode[k++] = 0x56; // JUMP
}
bytecode[k++] = 0x5b; // JUMPDEST
bytecode[k++] = 0x60; // PUSH1
bytecode[k++] = 0x01; // 1
ThreadMXBean thread = ManagementFactory.getThreadMXBean();
Runtime runtime = Runtime.getRuntime();
runtime.gc();
long initialMemory = runtime.totalMemory() - runtime.freeMemory();
long initialTime = thread.getCurrentThreadCpuTime();
testCode(bytecode, 15000 * 3 + 2, "0000000000000000000000000000000000000000000000000000000000000001");
long finalTime = thread.getCurrentThreadCpuTime();
long finalMemory = runtime.totalMemory() - runtime.freeMemory();
System.out.println(String.format("Execution Time %s nanoseconds", finalTime - initialTime));
System.out.println(String.format("Delta memory %s", finalMemory - initialMemory));
}
示例13: waitUntilInNative
import java.lang.management.ManagementFactory; //導入方法依賴的package包/類
/**
* Waits until {@link TestThread} is in native.
*/
public void waitUntilInNative() {
ThreadMXBean tmx = ManagementFactory.getThreadMXBean();
while (isAlive()) {
ThreadInfo ti = tmx.getThreadInfo(getId());
if (ti.isInNative()) {
return;
}
try {
Thread.sleep(1);
} catch (InterruptedException e) {
}
}
}
示例14: telnet
import java.lang.management.ManagementFactory; //導入方法依賴的package包/類
@Override
public String telnet(Channel channel, String message) {
StringBuilder sb = new StringBuilder();
//內存使用情況
MemoryMXBean mmxb = ManagementFactory.getMemoryMXBean();
long max = mmxb.getHeapMemoryUsage().getMax();
long used = mmxb.getHeapMemoryUsage().getUsed();
long init = mmxb.getHeapMemoryUsage().getInit();
long commit = mmxb.getHeapMemoryUsage().getCommitted();
sb.append("********Memory status******************").append(line);
sb.append("Max JVM Heap Memory:").append(max / 1024 / 1024).append("M").append(line)
.append("Used Heap Memory:").append(used / 1024 / 1024).append("M").append(line)
.append("Init Heap Memory:").append(init / 1024 / 1024).append("M").append(line)
.append("Commited Heap Memory:").append(commit/1024/1024).append("M").append(line);
sb.append("********Thread status********************").append(line);
//線程數
ThreadMXBean txmb = ManagementFactory.getThreadMXBean();
sb.append("Peak thread count:").append(txmb.getPeakThreadCount()).append("").append(line)
.append("Thread count:").append(txmb.getThreadCount()).append("").append(line);
sb.append("********Runtime status******************").append(line);
//啟動入口參數
RuntimeMXBean rmxb = ManagementFactory.getRuntimeMXBean();
sb.append("InputArguments:[");
for(String ia : rmxb.getInputArguments()){
sb.append(ia).append(",");
}
sb.deleteCharAt(sb.length()-1).append("]").append(line);
sb.append("JVM start time:").append(DateUtils.dateToStr(new Date(rmxb.getStartTime()))).append(line);
return sb.toString();
}
示例15: areOtherThreadsAllocatedMemory
import java.lang.management.ManagementFactory; //導入方法依賴的package包/類
/**
* Checks if threads other then the current thread were allocating objects
* after baselinedThreadMemoryUsage call.
*
* If baselinedThreadMemoryUsage was not called, then this method will return
* {@code false}.
*/
public boolean areOtherThreadsAllocatedMemory() {
if (baselinedThreadMemoryUsage == null) {
return false;
}
ThreadMXBean bean = (ThreadMXBean) ManagementFactory.getThreadMXBean();
long currentMemoryAllocation[]
= bean.getThreadAllocatedBytes(threadIds);
boolean otherThreadsAllocatedMemory = false;
System.out.println("Verifying amount of memory allocated by threads:");
for (int i = 0; i < threadIds.length; i++) {
System.out.format("Thread %d%nbaseline allocation: %d"
+ "%ncurrent allocation:%d%n", threadIds[i],
baselinedThreadMemoryUsage[i], currentMemoryAllocation[i]);
System.out.println(bean.getThreadInfo(threadIds[i]));
long bytesAllocated = Math.abs(currentMemoryAllocation[i]
- baselinedThreadMemoryUsage[i]);
if (bytesAllocated > 0
&& threadIds[i] != Thread.currentThread().getId()) {
otherThreadsAllocatedMemory = true;
}
}
return otherThreadsAllocatedMemory;
}