共计 1268 个字符,预计需要花费 4 分钟才能阅读完成。
作者:幻好
起源:恒生 LIGHT 云社区
引言
在我的项目代码重构过程中,代码标准中提到:禁止在办法内对对象类型的入参赋值(简略类型和 string 类型的入参容许赋值)
。那么大多数初学者会有疑难,这个标准提出的次要意义是什么呢?本文就来探索这个标准背地的目标。
援用传递和值传递
要想明确上述探索问题,首先得回去搞清楚 Java 根底中的援用传递和值传递概念。
根本定义
值传递 (pass by value):在调用函数时,将理论参数复制一份传递到函数中,如果在函数中对参数进行批改,就 不会影响 到原来的 理论参数。
- 值传递的数据类型,包含根本数据类型和 String 对象。
-
实例:
public static void main(String[] args) { int i = 1; String str = "值传递,不变"; passByValue(i, str); System.out.println("i 传递后 :" + i); System.out.println("str 传递后 :" + str); } public static void passByValue(int i, String str) { i = 0; str = "批改传递值"; System.out.println("i 传递值 :" + i); System.out.println("str 传递值 :" + str); } // 打印 ---------- i 传递值 : 0 str 传递值 : 批改传递值 i 传递后 : 1 str 传递后 : 值传递,不变
能够看出对于根本类型和 String 类型,值的传递后并不会扭转原有的值。
援用传递 (pass by reference):在调用函数时,将理论参数的地址间接传递到函数中,如果在函数中对参数进行的批改,就 会影响 到理论参数。
- 值传递的数据类型,包含数组、类、接口。
-
实例:
public static void main(String[] args) {Map<String, String> map = new HashMap<>(8); map.put("desc", "援用传递,值会变吗?"); passByRef(map); System.out.println("map 传递后 :" + map.toString()); } public static void passByRef(Map map) {map.put("desc", "批改援用传递"); System.out.println("map 传递值 :" + map.toString()); } // 打印 --------- map 传递值 : {desc= 批改援用传递} map 传递后 : {desc= 批改援用传递}
依据打印值,如果是援用传递,传递后的原值已被批改。
所以通过以上两个例子,能够明确 Java 中援用传递和值传递概念。
实质起因
因为 Java 程序设计语言是采纳的值传递,所以在在 Java 中没有指针的概念。也就是说办法失去的是所有参数值的一个拷贝,办法并不能批改传递给它的任何参数变量的内容。
基于上述设计准则,咱们在开发中应该遵循此准则进行开发,更重要的一点是,如果批改传参的值,会让前期对程序的保护难度减少。
所以在开发中,咱们更应该标准 code,进步代码品质。
正文完