Java 参数传递问题

Java参数传递

  • 给出了基本类型和引用类型参数传递时行为的示例,并给出了String类型作为参数传递时表现出的和一般引用类型传递行为不同的原因
  • 使用基本类型进行参数传递时的代码示例
public class Test1 {

        public static void main(String[] args) {

        int n = 3;

        System.out.println("Before change, n = " + n);

        changeData(n);

        System.out.println("After changeData(n), n = " + n);

    }
    public static void changeData(int nn) {
        n = 10;
    }
}
  • **基本类型作为参数传递时,是传递值的拷贝,无论你怎么改变这个拷贝,原值是不会改变的
    **,输出的结果证明了这一点:
    Before change, n = 3
    After changeData(n), n = 3

  • 使用引用类型进行参数传递的代码示例

public class Test2 {

       public static void main(String[] args) {

        StringBuffer sb = new StringBuffer("Hello ");

        System.out.println("Before change, sb = " + sb);

        changeData(sb);

        System.out.println("After changeData(n), sb = " + sb);

    }

    public static void changeData(StringBuffer strBuf) {

        strBuf.append("World!");
    }
}
  • 在Java中对象作为参数传递时,是把对象在内存中的地址拷贝了一份传给了参数
    Test2输出结果
    Before change, sb = Hello
    After changeData(n), sb = Hello World!
  • 传递引用型参数,并在子方法中对参数进行变更的一种情况
public class Test3 {

       public static void main(String[] args) {

        StringBuffer sb = new StringBuffer("Hello ");

        System.out.println("Before change, sb = " + sb);

        changeData(sb);

        System.out.println("After changeData(n), sb = " + sb);

    }

    public static void changeData(StringBuffer strBuf) {

           strBuf = new StringBuffer("Hi ");
           strBuf.append("World!");
    }
}

运行一下这个程序,结果是这样的:
Before change, sb = Hello
After changeData(n), sb = Hello

Java中的参数传递方式

  • 通过分析Java参数传递时的内存模型,给出了Java参数传递时内存中实际发生的行为
  • 基本类型代码示例和内存模型示意图
public class ParameterTransfer {
    public static void main(String[] args) {
        int num = 30;
        System.out.println("调用add方法前num=" + num);
        add(num);
        System.out.println("调用add方法后num=" + num);
    }
 
    public static void add(int param) {
        param = 100;
    }
}
Java 参数传递问题_第1张图片
调用前num变量内存状态

Java 参数传递问题_第2张图片
方法调用发生时全局变量num和add方法参数num的内存状态
  • 两个变量的内存都被分配在栈中,从内存地址的角度来看,对8600地址的修改,不会反映到8500地址上面
  • 使用引用类型时的代码示例和内存模型示例
public class ParameterTransfer {
    public static void main(String[] args) {
        String[] array = new String[] {"huixin"};
        System.out.println("调用reset方法前array中的第0个元素的值是:" + array[0]);
        reset(array);
        System.out.println("调用reset方法后array中的第0个元素的值是:" + array[0]);
    }
 
    public static void reset(String[] param) {
       param[0] = "hello, world!";
    }
}

Java 参数传递问题_第3张图片
调用前全局array变量的内存状态

Java 参数传递问题_第4张图片
调用时全局array变量和方法参数array的内存状态

Java 参数传递问题_第5张图片
在reset方法中进行修改后,两个array变量的内存状态

在Java语言中,以String作为类型的变量在作为方法参数时所表现出的“非对象”的特性

基本结论

基本类型作为参数传递时,是传递值的拷贝,无论你怎么改变这个拷贝,原值是不会改变的
****在****Java****中对象作为参数传递时,是把对象在内存中的地址拷贝了一份传给了参数****
****在参数列表中的变量,和传递进方法的参数,不在同一个地址上面****

你可能感兴趣的:(Java 参数传递问题)