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
上一篇下一篇

猜你喜欢

热点阅读