Java本机方法源代码

时间:2012-09-26 03:09:51

标签: java

我在哪里可以下载java原生方法源代码?例如,我想知道System.arraycopy()的源代码,但我找不到。

2 个答案:

答案 0 :(得分:31)

您可以下载OpenJdk源代码here

在文件夹jdk\src\share中,您可以获得源代码。

jdk\src\share\native是用c和c ++写的natice方法。

  1. jdk\src\linux linux的源代码。
  2. jdk\src\windows Windows的来源。
  3. jdk\src\solaris来源于solaris。
  4. jd\src\share共同来源。
  5. 例如:System.arrayCopy();

    int file 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', i.e., s.length(),
    // points to the right of the last element.
    if (length==0) {
      return;
    }
    if (UseCompressedOops) {
      narrowOop* const src = objArrayOop(s)->obj_at_addr<narrowOop>(src_pos);
      narrowOop* const dst = objArrayOop(d)->obj_at_addr<narrowOop>(dst_pos);
      do_copy<narrowOop>(s, src, d, dst, length, CHECK);
    } else {
      oop* const src = objArrayOop(s)->obj_at_addr<oop>(src_pos);
      oop* const dst = objArrayOop(d)->obj_at_addr<oop>(dst_pos);
      do_copy<oop> (s, src, d, dst, length, CHECK);
      }
    }
    

答案 1 :(得分:2)

本机方法,并由您正在使用的虚拟机以不同方式实现。这种方法没有一种实现方式,实际上不同的代码可以在不同的体系结构或虚拟机上执行。