java字符串调用函数参数传递_Java方法的参数传递机制实例详解

本文实例讲述了Java方法的参数传递机制。分享给大家供大家参考,具体如下:

参数传递机制

对于程序设计语言来说,一般方法(函数)的参数传递有两种:按值传递和按引用传递。

按值传递意味着当将一个参数传递给一个方法时,方法接收的是原始值的一个副本。因此,如果方法修改了该参数,仅改变副本,而原始值保持不变。按引用传递意味着当将一个参数传递给一个方法时,方法接收的是原始值的内存地址,而不是值的副本。因此,如果方法修改了该参数,调用代码中的原始值也随之改变。

需要注意的是,方法可以修改按引用传递的参数对应的变量值,但不可以修改按值传递的参数对应的变量值,这是两者的最大区别。

Java中的参数传递

Java中的参数传递机制只有一种,就是值传递。在Java中并没有C++的引用传递这种参数传递机制,它所有的参数传递都遵循值传递的机制。

Java中对于对象(数组,类,接口)的传递似乎有点像引用传递,可以改变对象中某个属性的值。但是不要被这个假象所蒙蔽,实际上这个传入方法的值是对象引用的拷贝,即传递的是引用的地址值,所以还是按值传递。

基本类型的参数传递

在方法调用时,传递的参数是按值的拷贝传递;

public class Test {

public static void main(String[] args) {

Test t = new Test();

int a = 5;

t.method(a); // 传递后,method方法对变量值的改变不影响这里的a

System.out.println("method调用完后的a: " + a);

}

private void method(int a){

System.out.println("method中重新赋值之前的a: " + a);

a = 10;

System.out.println("method中重新赋值之后的a: " + a);

}

}

执行结果如下:

method中重新赋值之前的a: 5

method中重新赋值之后的a: 10

method调用完后的a: 5

由此可知按值传递重要特点:传递的是值的拷贝,也就是说传递后就互不相关了。下面看一下内存分析:

1e14d450cef6ffcc5ab8ad2c6c1f43cc.png

引用类型的参数传递

在方法调用时,传递的参数按引用进行传递,其实传递的引用的地址,也就是变量所对应的内存空间的地址。

public class Test {

public static void main(String[] args) {

Person person = new Person();

person.age = 18;

// 把main方法中的变量person所引用的内存空间地址,按引用传递给method方法中的person变量

// 请注意:这两个person变量是完全不同的,不要被名称相同所蒙蔽

method(person);

System.out.println("调用method方法之后:" + person.age);

}

public static void method(Person person){

person.age = 20;

System.out.println("method方法内第一次修改:" + person.age);

person = new Person(); // 新创建一个对象

person.age = 25;

System.out.println("method方法内第二次修改:" + person.age);

}

}

class Person {

public int age;

}

执行结果如下:

method方法内第一次修改:20

method方法内第二次修改:25

调用method方法之后:20

这里传递的是值的引用,也就是说传递前和传递后都指向同一个引用(也就是同一个内存空间)。

e2e50c32e27e1e1804fd759a6e376072.png

下面我们接着看一个例子:

public class Test {

public static void main(String[] args) {

int[] a = {5, 10};

method(a);

System.out.println("调用完method方法之后:" + a[0]);

}

public static void method(int[] a){

System.out.println("method内修改a[0]之前:" + a[0]);

a[0] = 50;

System.out.println("method内修改a[0]之后:" + a[0]);

}

}

执行结果如下:

method内修改a[0]之前:5

method内修改a[0]之后:50

调用完method方法之后:50

根据结果可知,调用method方法时实际传递的是引用的地址值。

e0b03d48083bd83ddf47ef4a08c41575.png

传递String类型的参数

由于String类是final修饰的,不可变,它会在内存中在开辟一块新空间。

public class Test {

public static void main(String[] args) {

String str1 = new String("test1");

String str2 = "test2";

method(str1, str2);

System.out.println("调用method传参str1之后:" + str1 + ", " + str2);

}

public static void method(String str1, String str2){

System.out.println("method内修改str之前:" + str1 + ", " + str2);

str1 = "new1";

str2 = "new2";

System.out.println("method内修改str之后:" + str1 + ", " + str2);

}

}

执行结果如下:

method内修改str之前:test1, test2

method内修改str之后:new1, new2

调用method传参str1之后:test1, test2

总结:

1)基本数据类型传递的是值的复制,对一个参数的修改不会影响另一个参数;

2)引用类型传引用,形参和实参指向同一个内存地址(同一个对象),所以对参数的修改会影响到实际的对象;

3)String、Integer、Double等immutable的类型特殊处理,可以理解为传值,最后的操作不会修改实参对象(与基本数据类型一致)。

希望本文所述对大家java程序设计有所帮助。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值