如何讀open jdk native 源碼

怎麼看open jdk native的源碼

  1. 類的命名與java類的命名是如出一轍的
  2. 方法的命名爲JNI的代碼風格
  3. 通常關注下文件頭,若是是系統文件,好比 <sys/socket.h>, 是搜不到源碼的,不然全局能夠搜到對應的命名

JVM_ENTRY等相似這樣的字符是啥意思?

JVM_ENTRY自己是一個宏定義,位於interfaceSupport.hpp中html

#define JVM_ENTRY(result_type, header)                               \ //宏定義,每一個使用這個名字的地方,都會被宏的內容所替代
extern "C" {                                                         \ //表示編譯器須要按照C的方式編譯
  result_type JNICALL header {                                       \
    JavaThread* thread=JavaThread::thread_from_jni_environment(env); \
    ThreadInVMfromNative __tiv(thread);                              \
    debug_only(VMNativeEntryWrapper __vew;)                          \
    __ENTRY(result_type, header, thread)
extern "C" 解釋

宏定義java

jvm_entry作了什麼segmentfault

例子

java中有一個AccessController.doPrivileged方法。它對應的實現是在jvm.cpp中,原始代碼爲app

JVM_ENTRY(jobject, JVM_DoPrivileged(JNIEnv *env, jclass cls, jobject action, jobject context, jboolean wrapException))
              #這裏是省略的方法體
JVM_END

轉換後jvm

extern "C" {                                                         \ 
  jobject JNICALL JVM_DoPrivileged(JNIEnv *env, jclass cls, jobject action, jobject context, jboolean wrapException) {                                       \
    JavaThread* thread=JavaThread::thread_from_jni_environment(env); \
    ThreadInVMfromNative __tiv(thread);                              \
    debug_only(VMNativeEntryWrapper __vew;)                          \
    __ENTRY(result_type, header, thread) 
            #這裏是省略的方法體                                                  
      
                }
           }

附錄

JNI 簡介socket

相關文章
相關標籤/搜索