提交 36490a1a 编写于 作者: M mchung

6977034: Thread.getState() very slow

Summary: Directly map the threadStatus value to Thread.State
Reviewed-by: emcmanus, dholmes
上级 202e2619
...@@ -209,7 +209,7 @@ class Thread implements Runnable { ...@@ -209,7 +209,7 @@ class Thread implements Runnable {
* initialized to indicate thread 'not yet started' * initialized to indicate thread 'not yet started'
*/ */
private int threadStatus = 0; private volatile int threadStatus = 0;
private static synchronized long nextThreadID() { private static synchronized long nextThreadID() {
......
...@@ -25,6 +25,7 @@ ...@@ -25,6 +25,7 @@
package sun.misc; package sun.misc;
import static java.lang.Thread.State.*;
import java.util.Properties; import java.util.Properties;
import java.util.HashMap; import java.util.HashMap;
import java.util.Map; import java.util.Map;
...@@ -332,69 +333,37 @@ public class VM { ...@@ -332,69 +333,37 @@ public class VM {
} }
} }
/**
* Returns Thread.State for the given threadStatus
*/
public static Thread.State toThreadState(int threadStatus) { public static Thread.State toThreadState(int threadStatus) {
// Initialize the threadStateMap if ((threadStatus & JVMTI_THREAD_STATE_RUNNABLE) != 0) {
initThreadStateMap(); return RUNNABLE;
} else if ((threadStatus & JVMTI_THREAD_STATE_BLOCKED_ON_MONITOR_ENTER) != 0) {
Thread.State s = threadStateMap.get(threadStatus); return BLOCKED;
if (s == null) { } else if ((threadStatus & JVMTI_THREAD_STATE_WAITING_INDEFINITELY) != 0) {
// default to RUNNABLE if the threadStatus value is unknown return WAITING;
s = Thread.State.RUNNABLE; } else if ((threadStatus & JVMTI_THREAD_STATE_WAITING_WITH_TIMEOUT) != 0) {
} return TIMED_WAITING;
return s; } else if ((threadStatus & JVMTI_THREAD_STATE_TERMINATED) != 0) {
return TERMINATED;
} else if ((threadStatus & JVMTI_THREAD_STATE_ALIVE) == 0) {
return NEW;
} else {
return RUNNABLE;
} }
// a map of threadStatus values to the corresponding Thread.State
private static Map<Integer, Thread.State> threadStateMap = null;
private static Map<Integer, String> threadStateNames = null;
private synchronized static void initThreadStateMap() {
if (threadStateMap != null) {
return;
} }
final Thread.State[] ts = Thread.State.values(); /* The threadStatus field is set by the VM at state transition
* in the hotspot implementation. Its value is set according to
final int[][] vmThreadStateValues = new int[ts.length][]; * the JVM TI specification GetThreadState function.
final String[][] vmThreadStateNames = new String[ts.length][]; */
getThreadStateValues(vmThreadStateValues, vmThreadStateNames); private final static int JVMTI_THREAD_STATE_ALIVE = 0x0001;
private final static int JVMTI_THREAD_STATE_TERMINATED = 0x0002;
threadStateMap = new HashMap<Integer, Thread.State>(); private final static int JVMTI_THREAD_STATE_RUNNABLE = 0x0004;
threadStateNames = new HashMap<Integer, String>(); private final static int JVMTI_THREAD_STATE_BLOCKED_ON_MONITOR_ENTER = 0x0400;
for (int i = 0; i < ts.length; i++) { private final static int JVMTI_THREAD_STATE_WAITING_INDEFINITELY = 0x0010;
String state = ts[i].name(); private final static int JVMTI_THREAD_STATE_WAITING_WITH_TIMEOUT = 0x0020;
int[] values = null;
String[] names = null;
for (int j = 0; j < ts.length; j++) {
if (vmThreadStateNames[j][0].startsWith(state)) {
values = vmThreadStateValues[j];
names = vmThreadStateNames[j];
}
}
if (values == null) {
throw new InternalError("No VM thread state mapped to " +
state);
}
if (values.length != names.length) {
throw new InternalError("VM thread state values and names " +
" mapped to " + state + ": length not matched" );
}
for (int k = 0; k < values.length; k++) {
threadStateMap.put(values[k], ts[i]);
threadStateNames.put(values[k], names[k]);
}
}
}
// Fill in vmThreadStateValues with int arrays, each of which contains
// the threadStatus values mapping to the Thread.State enum constant.
// Fill in vmThreadStateNames with String arrays, each of which contains
// the name of each threadStatus value of the format:
// <Thread.State.name()>[.<Substate name>]
// e.g. WAITING.OBJECT_WAIT
//
private native static void getThreadStateValues(int[][] vmThreadStateValues,
String[][] vmThreadStateNames);
static { static {
initialize(); initialize();
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册