- 类的命名与java类的命名是一模一样的
- 方法的命名为JNI的代码风格
- 一般关注下文件头,如果是系统文件,比如 <sys/socket.h>, 是搜不到源码的,否则全局可以搜到对应的命名
- 对于类的定义可以通过
class 类名
这种方式搜索。一些特殊的形式,比如markOop
,它是个类别名的定义,定义为typedef class markOopDesc* markOop;
- 一些常量有好几种方式,比如
TRAPS
CHECK
是宏定义,可以通过define TRAPS
查找;比如UseBiasedLocking
这种是java的启动参数;
JVM_ENTRY等类似这样的字符是啥意思?
JVM_ENTRY本身是一个宏定义,位于interfaceSupport.hpp中
代码语言:javascript复制#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" 解释
宏定义
jvm_entry做了什么
例子
java中有一个AccessController.doPrivileged方法。它对应的实现是在jvm.cpp中,原始代码为
代码语言:javascript复制JVM_ENTRY(jobject, JVM_DoPrivileged(JNIEnv *env, jclass cls, jobject action, jobject context, jboolean wrapException))
#这里是省略的方法体
JVM_END
转换后
代码语言:javascript复制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)
#这里是省略的方法体
}
}
构造函数
c 的构造语法,冒号后面的内容表示初始化对应的字段,比如_bulk_rebias(bulk_rebias)
表示赋值字段_bulk_rebias
VM_BulkRevokeBias(Handle* obj, JavaThread* requesting_thread,
bool bulk_rebias,
bool attempt_rebias_of_object)
: VM_RevokeBias(obj, requesting_thread)
, _bulk_rebias(bulk_rebias) //表示初始化对应的字段
, _attempt_rebias_of_object(attempt_rebias_of_object) {}
创建新的变量,如下形式其实是创建了RegisterMap
的实例,实例的名字是 rm,构造函数只有1个参数
RegisterMap rm(thread);
附录
JNI 简介