JNI_CreateJavaVM位于jni.cpp中。
很显然JNI_CreateJavaVM也只是一个Wrapper,它调用了Threads::create_vm
其中有意思的代码是:
result = Threads::create_vm((JavaVMInitArgs*) args, &can_try_again);
if (result == JNI_OK) {
JavaThread *thread = JavaThread::current();
/* thread is thread_in_vm here */
*vm = (JavaVM *)(&main_vm);
*(JNIEnv**)penv = thread->jni_environment();
//.....
}
很显然JNI_CreateJavaVM也只是一个Wrapper,它调用了Threads::create_vm
其中有意思的代码是:
result = Threads::create_vm((JavaVMInitArgs*) args, &can_try_again);
if (result == JNI_OK) {
JavaThread *thread = JavaThread::current();
/* thread is thread_in_vm here */
*vm = (JavaVM *)(&main_vm);
*(JNIEnv**)penv = thread->jni_environment();
//.....
}
vm和penv是JNI_CreateJavaVM的入口参数。
来看看vm参数是如何获得的。
vm实际上就被指向了全局变量main_vm。
jni.cpp line 2782
extern struct JavaVM_ main_vm;
extern struct JavaVM_ main_vm;
jni.cpp line 3157
struct JavaVM_ main_vm = {&jni_InvokeInterface};
struct JavaVM_ main_vm = {&jni_InvokeInterface};
这里有一个C的语法知识点: extern变量的声明和定义。
line 2782是一个声明,line 3157 才是main_vm的定义。
line 2782是一个声明,line 3157 才是main_vm的定义。
在jvmtiExport.cpp、os.cpp、thread.cpp中引用了main_vm这个全局变量。