关于java:Java代码重构时为什么禁止在方法内对对象类型的入参赋值

46次阅读

共计 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,进步代码品质。

正文完
 0