通俗易懂的Java的参数传递

2019-07-06  本文已影响0人  浩泽Hauser

对于Java八大基本数据类型,是值传递
Java的8大基本数据类型( 8 primitive types )分别是:
(1)整数类 byte, short, int, long
(2)浮点数类 double, float
(3)逻辑类 boolean
(4)文本类 char
如果是对基本数据类型的数据进行操作,由于是把值传递进去,而数据本身不变,因此对于形参的操作,不影响原始内容。
例如:

int a = 4;
helper(a);               helper()中 a = 8 或者 a+=4,无论怎么操作原a都不会改变
System.out.println(a);   a的值仍为4,

对于非数据类型,也是值传递,这里的值是指原地址的副本
如果是对引用类型( non-primitive types, reference types )的数据进行操作,分两种情况:
(1)形参(原数据copy)和实参(原数据)保持指向同一个对象地址,则形参的操作,会影响实参指向的对象的内容。
(2)形参的指针被改动,指向新的对象地址(如重新赋值引用),则形参的操作,不会影响实参指向的对象的内容。

以ListNode为例。ListNode 内部存有 int val和 ListNode next, 若是直接修改 val和next,就会导致原ListNode的改变;否则就不会影响原ListNode。

  public class ListNode {       // ListNode class的代码
      int val;
      ListNode next;
      ListNode(int x) {
          val = x;
          next = null;
      }
  }
ListNode L1 = new ListNode(1);   L1.next = L2;
ListNode L2 = new ListNode(2);   L2.next = L3;  
helperA(L1);       在helperA()中: L1.val = 10; L1.next = L3;  原L1和helperA中的参数都指向同一个地址,所以会影响
System.out.println(L1.val);    这时L1.val 和 L1.next 都改变了,是情况(1)
helperB(L2);       在helperB()中: L1 = L1.next; 
                   helperB中参数指向的地址由L1变成了L1.next, 不再共享地址,所以不会影响L1,是情况(2) 

以String 为例

String a = "123"; 
helperA(a); helperB(a);  在helperA中 a = "456", helperB中 a = new String("xxx"); 
                                       两种情况下,参数的指向地址都改变了,所以不会影响原a 
System.out.println(a);  得到 a = "123"

另外,int 都是以值进行记录,所以 int 都用 == 比较。对于Integer,在[-128, 127] 范围内是以值进行记录,可以用 == 比较,而超过这范围的 Integer 必须用 .equals() 比较。

(Integer)129 == (Integer)129 :   false
(Integer)127 == (Integer)127 :   true
(int)  1000 == (int)  1000  : true  

参考:
https://juejin.im/post/5bce68226fb9a05ce46a0476

上一篇下一篇

猜你喜欢

热点阅读