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;
    }
}
调用前num变量内存状态

方法调用发生时全局变量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!";
    }
}

调用前全局array变量的内存状态

调用时全局array变量和方法参数array的内存状态

在reset方法中进行修改后,两个array变量的内存状态

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

基本结论

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

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,779评论 18 399
  • 一、 1、请用Java写一个冒泡排序方法 【参考答案】 public static void Bubble(int...
    独云阅读 1,426评论 0 6
  • 小编费力收集:给你想要的面试集合 1.C++或Java中的异常处理机制的简单原理和应用。 当JAVA程序违反了JA...
    八爷君阅读 4,681评论 1 114
  • [TOC] StringBuffer类 StringBuffer类概述及其构造方法 StringBuffer类概述...
    lutianfei阅读 491评论 0 1
  • 今天是周五,作业很多,傅杨琳和牛牧童最难完成的一项作业是试卷,因为她俩几乎认识不了卷面上的几个字。我只好先让她俩认...
    甜甜书屋阅读 333评论 0 1