实参与形参的传递关系
2016-04-22 13:04
302 查看
当我们在主调函数中调用方法的时候,需要把类型匹配的实际的数据传入到方法中。传进去的那个数据就是实参,而在方法定义中接收参数的那个变量就是形参。下面分三种情况讨论:
1、传递基本数据类型:
这种情况下,实参是把值传递给形参,形参在函数中改变值不会影响实参。
2、传递实体对象:
这种情况中,实参实际是把对象在堆栈中的地址传递给形参。当形参变量调用方法改变值时,其实改变的是指向这个对象的值,因此执行完退出函数后,对象的值已经改变,当我们主调函数继续使用这个对象时,值也会随之改变了。
3、传入NULL:
当我们在传递对象的时候,传入的是一个NULL时,即便在函数中传建一个实例并指向形参,函数结束后,实参依然是NULL的。这里也很好地说明了实参向形参传递值是单向的,不管是基本类型还是引用类型,传递都是单向的。只是基本类型传递的就是值本身,而引用类型传递的是引用地址。
下面是实验的代码:
1、传递基本数据类型:
这种情况下,实参是把值传递给形参,形参在函数中改变值不会影响实参。
2、传递实体对象:
这种情况中,实参实际是把对象在堆栈中的地址传递给形参。当形参变量调用方法改变值时,其实改变的是指向这个对象的值,因此执行完退出函数后,对象的值已经改变,当我们主调函数继续使用这个对象时,值也会随之改变了。
3、传入NULL:
当我们在传递对象的时候,传入的是一个NULL时,即便在函数中传建一个实例并指向形参,函数结束后,实参依然是NULL的。这里也很好地说明了实参向形参传递值是单向的,不管是基本类型还是引用类型,传递都是单向的。只是基本类型传递的就是值本身,而引用类型传递的是引用地址。
下面是实验的代码:
package demo; public class TestOfPiont { public static void main(String[] args) { // TODO Auto-generated method stub TestOfPiont test= new TestOfPiont(); Person p = test.new Person("jack", 33); test.newone(p); System.out.println(p.name); test.change(p); System.out.println(p.name); int x=2; test.basechange(x); System.out.println(x); } void newone(Person p){ p = new Person("mike", 22); } void change(Person p){ p.name="mike"; } void basechange(int x){ x=5; } class Person{ private String name; private int age; public Person(String name, int age) { super(); this.name = name; this.age = age; } } } //结果为: jack mike 2
相关文章推荐
- Java 6 JVM参数选项大全(中文版)
- Mootools 1.2教程 函数
- autoit 命令行参数说明
- autoit InputBox 函数
- 给IE加个参数 永远不怕IE主页被修改
- 文件遍历排序函数
- Oracle 函数大全[字符串函数,数学函数,日期函数]第1/4页
- ASP下经常用的字符串等函数参考资料
- PostgreSQL教程(五):函数和操作符详解(1)
- DOS批处理 函数定义与用法
- asp Chr 函数 数字转字母的方法
- Lua中的函数精讲笔记
- Lua中的闭合函数、非全局函数与函数的尾调用详解
- Lua中调用C++函数示例
- Lua实现split函数
- Lua常用时间函数使用实例
- Lua函数与字符串处理简明总结
- Lua学习笔记之表和函数
- Lua中实现sleep函数功能的4种方法
- Lua函数用法研究