org.jppf.management.diagnostics.ThreadDump Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of jppf-common Show documentation
Show all versions of jppf-common Show documentation
JPPF, the open source grid computing solution
/*
* JPPF.
* Copyright (C) 2005-2015 JPPF Team.
* http://www.jppf.org
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.jppf.management.diagnostics;
import java.io.Serializable;
import java.lang.management.*;
import java.util.*;
/**
* This class encapsulates a JVM thread dump, including dealocks information when available.
* @author Laurent Cohen
*/
public class ThreadDump implements Serializable
{
/**
* Information on the threads.
*/
private final Map threads;
/**
* The ids of the deadlocked threads.
*/
private final long[] deadlockedThreads;
/**
* Create this thread dump from the specified thread mxbean.
* @param threadMXBean the thread MXBean to get the information from.
*/
public ThreadDump(final ThreadMXBean threadMXBean)
{
ThreadInfo[] tis = threadMXBean.dumpAllThreads(threadMXBean.isObjectMonitorUsageSupported(), threadMXBean.isSynchronizerUsageSupported());
if ((tis == null) || (tis.length <= 0)) threads = null;
else
{
threads = new TreeMap<>();
for (ThreadInfo ti: tis) threads.put(ti.getThreadId(), new ThreadInformation(ti));
}
long[] ids = threadMXBean.isSynchronizerUsageSupported() ? threadMXBean.findDeadlockedThreads() : null;
this.deadlockedThreads = (ids == null) || (ids.length <= 0) ? null : ids;
}
/**
* Get information on the threads.
* @return a mapping of {@link ThreadInformation} objects to their thread id, or null
if no thread information is available.
*/
public Map getThreads()
{
return threads;
}
/**
* Get the ids of the deadlock threads, if any.
* @return the ids as an array of long
values, or null
if none exists.
*/
public long[] getDeadlockedThreads()
{
return deadlockedThreads;
}
@Override
public String toString()
{
return TextThreadDumpWriter.printToString(this, "ThreadDump");
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy