形参是实参的拷贝,改变形参的值并不会影响外部实参的值。从被调用函数的角度来说,值传递是单向的(实参->形参),参数的值只能传入,不能传出。当函数内部需要修改参数,并且不希望这个改变影响调用者时,采用值传递。
2.指针传递
指针从本质上讲就是存放变量地址的一个变量,在逻辑上是独立的,它可以被改变,包括其所指向的地址的改变和其指向的地址中所存放的数据的改变。
3.引用传递
引用则是某块内存的别名。引用是操作受限了的指针(仅容许取内容操作)。
引用只能在定义时被初始化一次,之后不可变,不可为空。
int a = 1;
int b = 2;
int &m = a; //m被初始化为a的引用
int &n = b;
m = b; //并不能将m修改成为b的引用(引用的对象不可被改变), 只是把引用m的值改变成为6。 由于m是a的引用,所以a的值也变成了6。
最后,总结一下指针和引用的相同点和不同点:
★相同点:
●都是地址的概念;
指针指向一块内存,它的内容是所指内存的地址;而引用则是某块内存的别名。
★不同点:
●指针是一个实体,而引用仅是个别名;
●引用只能在定义时被初始化一次,之后不可变;指针可变;引用“从一而终”,指针可以“见异思迁”;
●引用没有const,指针有const,const的指针不可变;(具体指没有int& const a这种形式,而const int& a是有 的, 前者指引用本身即别名不可以改变,这是当然的,所以不需要这种形式,后者指引用所指的值不可以改变)
●引用不能为空,指针可以为空;
●“sizeof 引用”得到的是所指向的变量(对象)的大小,而“sizeof 指针”得到的是指针本身的大小;
●指针和引用的自增(++)运算意义不一样;
●引用是类型安全的,而指针不是 (引用比指针多了类型检查)
关于java中包装类型和对象类型的传递:
1.包装类型参数为值传递
2.对象类型参数为地址传递
public class Test{
static Test test=new Test();
public int i=1;
public static void main(String[] args) {
System.out.println(test+":main1"+":"+test.i); //输出 Test@c17164:main1:1
test.print(test);
System.out.println(test+":main2"+":"+test.i);//输出 Test@c17164:main2:2,因print方法中将obj对象变量i值改变为2
}
public void print(Object obj){
((Test)obj).i=2;
System.out.println(obj+":print1"+":"+((Test)obj).i);//输出 Test@c17164:main1:2
obj=new Test(); //实例化Test,变量obj存放该新实例的地址。
((Test)obj).i=3;
System.out.println(obj.toString()+":print2"+":"+((Test)obj).i); //输出 Test@1fb8ee3:print2:3 ,因变量obj指向新的Test实例,对象存储的物理地址不同,故输出的hashCode不同
}
}
由代码可看出,对象变量的引用是可发生变化的,即java中对象的传递是地址传递,非引用传递。