java获取真实线程id
2020-08-16 本文已影响0人
摆渡时光
以下代码获取的threadId其实是jvm里的线程id,和我们常说的linux系统线程id不一样
public static void main(String[] a) {
long tid = Thread.currentThread().getId();
System.out.println("tid:"+ tid);
}
打印结果
tid:1
从结果看明显id不是我们想要的系统线程id。系统线程id可以借助jni调用c去获取
首先定义包含native方法的java文件GetThreadID.java
public class GetThreadID {
public static native int getTid();
static {
System.loadLibrary("GetThreadID");
}
}
然后定义c函数文件GetThreadID.c
#include <jni.h>
#include <sys/syscall.h>
#include <unistd.h>
#include "GetThreadID.h"
JNIEXPORT jint JNICALL
Java_GetThreadID_get_1tid(JNIEnv *env, jobject obj) {
jint tid = syscall(__NR_gettid);
return tid;
}
最后改下我们获取线程的测试类test.java
public static void main(String[] a) {
long tid = GetThreadID.getTid();
System.out.println("tid:"+ tid);
}
执行如下命令编译和执行测试类
JAVA_HOME2=$(readlink -f /usr/jdk/bin/javac | sed "s:bin/javac::")
export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:.
javac GetThreadID.java
javah GetThreadID
gcc -I${JAVA_HOME2} -fPIC -shared GetThreadID.c -o libGetThreadID.so
javac test.java
java test
最后打印了系统线程id
tid:13141