Java原生方法源代码
我在哪里可以下载java本机方法源代码? 例如,我想知道System.arraycopy()
的源代码,但我找不到。
您可以在此处下载OpenJdk源代码。
在jdk\src\share
文件夹中,您可以获得源代码。
jdk\src\share\native
是用c和c ++写的natice方法。
-
jdk\src\linux
源代码。 -
jdk\src\windows
源代码。 -
jdk\src\solaris
源。 -
jd\src\share
常见的来源。
例如:System.arrayCopy();
int文件hotspot\src\share\vm\oops\objArrayKlass.cpp
第168行:
void objArrayKlass::copy_array(arrayOop s, int src_pos, arrayOop d, int dst_pos, int length, TRAPS) { assert(s->is_objArray(), "must be obj array"); if (!d->is_objArray()) { THROW(vmSymbols::java_lang_ArrayStoreException()); } // Check is all offsets and lengths are non negative if (src_pos < 0 || dst_pos < 0 || length < 0) { THROW(vmSymbols::java_lang_ArrayIndexOutOfBoundsException()); } // Check if the ranges are valid if ( (((unsigned int) length + (unsigned int) src_pos) > (unsigned int) s->length()) || (((unsigned int) length + (unsigned int) dst_pos) > (unsigned int) d->length()) ) { THROW(vmSymbols::java_lang_ArrayIndexOutOfBoundsException()); } // Special case. Boundary cases must be checked first // This allows the following call: copy_array(s, s.length(), d.length(), 0). // This is correct, since the position is supposed to be an 'in between point', ie, s.length(), // points to the right of the last element. if (length==0) { return; } if (UseCompressedOops) { narrowOop* const src = objArrayOop(s)->obj_at_addr(src_pos); narrowOop* const dst = objArrayOop(d)->obj_at_addr (dst_pos); do_copy (s, src, d, dst, length, CHECK); } else { oop* const src = objArrayOop(s)->obj_at_addr(src_pos); oop* const dst = objArrayOop(d)->obj_at_addr (dst_pos); do_copy (s, src, d, dst, length, CHECK); } }
本机方法,并由您正在使用的虚拟机以不同方式实现。 该方法没有一种实现方式,实际上可以在不同的体系结构或VM上执行不同的代码。