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参数传递时内存中实际发生的行为

基本类型代码示例和内存模型示意图

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;

}

}

ab173f5b3a71?nomobile

调用前num变量内存状态

ab173f5b3a71?nomobile

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

}

}

ab173f5b3a71?nomobile

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

ab173f5b3a71?nomobile

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

ab173f5b3a71?nomobile

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

基本结论

基本类型作为参数传递时,是传递值的拷贝,无论你怎么改变这个拷贝,原值是不会改变的

****在****Java****中对象作为参数传递时,是把对象在内存中的地址拷贝了一份传给了参数****

****在参数列表中的变量,和传递进方法的参数,不在同一个地址上面****

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值