Java中函数参数传递和数据存储

简介: 值传递是将要传递的值作为一副本传递的..引用传递,传递的是引用对象的内存地址..例如:int i=4;  int j=i;   //相当于把4复制了一个副本赋给了j输出结果是i=4 ,j=4Cint *p,*p1;int j=5;p=j;    //这里是把j在内存当中的地址赋给了指针pp1=p;   //这里是把指针p中保存的地址(就是j的地址)赋给了指针p1j=4;    //这里改变j的

值传递是将要传递的值作为一副本传递的..
引用传递,传递的是引用对象的内存地址..

例如:

int i=4;  
int j=i;   //相当于把4复制了一个副本赋给了j

输出结果是i=4 ,j=4

C
int *p,*p1;
int j=5;
p=j;    //这里是把j在内存当中的地址赋给了指针p
p1=p;   //这里是把指针p中保存的地址(就是j的地址)赋给了指针p1

j=4;    //这里改变j的值

输出结果是  j=4  ,  *p=4  ,  *p1=4  //因为p和p1指向的都是j  所以他们的值随j值改变

(以上说明和代码来自http://zhidao.baidu.com/question/31191252.html)


Java中函数参数的传递是值传递还是引用传递?

Java中参数传递时传递到函数中的参数都是原变量的一份拷贝,对于非类类型如int,float等,这份拷贝自然和原变量脱离了关系,这不难理解;
而对于类的实例而言,这份拷贝恰巧是实例引用的拷贝,它(参数)指向的实例地址和原实例引用指向的实例地址都是一样的,因此对参数的修改有时也会影响到实 例本身,故此造成了Java传递类实例是传递的引用即地址的假象,如下面例子中的changeMemberField函数,但是我们把参数指向的地址改到 别的实例上时,如changeMember函数,我们会发现参数和原实例引用再也不会发生关系了,这里证明Java中参数传递是完完全全是传值而不是传 址。

例子代码:

代码:


  1. package com.sitinspring;  

  2.   

  3. public class ChangeClass{  

  4.     public void changeInt(int i){  

  5.         i=5;  

  6.     }  

  7.       

  8.     public void changeLong(long i){  

  9.         i=555;  

  10.     }  

  11.       

  12.     public void changeString(String str){  

  13.         str="5555";  

  14.     }  

  15.       

  16.     public void changeMember(Member member){  

  17.         member=new Member("Cindy",35);  

  18.     }  

  19.       

  20.     public void changeMemberField(Member member){  

  21.         member.setAge(20);  

  22.         member.setName("Andy");  

  23.     }  

  24.       

  25.     public static void main(String[] args){  

  26.         ChangeClass changeClass=new ChangeClass();  

  27.           

  28.         int intValue=10;  

  29.         changeClass.changeInt(intValue);  

  30.         System.out.println(intValue);  

  31.           

  32.         long longValue=10;  

  33.         changeClass.changeLong(longValue);  

  34.         System.out.println(longValue);  

  35.           

  36.         String stringValue="1234";  

  37.         changeClass.changeString(stringValue);  

  38.         System.out.println(stringValue);          

  39.           

  40.         Member member2=new Member("Douglas",45);  

  41.         changeClass.changeMember(member2);  

  42.         System.out.println(member2);  

  43.           

  44.         Member member=new Member("Bill",25);  

  45.         changeClass.changeMemberField(member);  

  46.         System.out.println(member);  

  47.     }  

  48. }  



  1. package com.sitinspring;  

  2.   

  3. public class Member{  

  4.     private String name;  

  5.     private int age;  

  6.       

  7.     public Member(String name,int age){  

  8.         this.age=age;  

  9.         this.name=name;  

  10.     }  

  11.       

  12.     public String toString(){  

  13.         return "Member name="+name+" age="+age;  

  14.     }  

  15.   

  16.     public int getAge() {  

  17.         return age;  

  18.     }  

  19.   

  20.     public void setAge(int age) {  

  21.         this.age = age;  

  22.     }  

  23.   

  24.     public String getName() {  

  25.         return name;  

  26.     }  

  27.   

  28.     public void setName(String name) {  

  29.         this.name = name;  

  30.     }      

  31. }  


输出

10
10
1234
Member name
=Douglas age=45
Member name
=Andy age=20

 

解释
第一个输出10是因为int是基本类型,传递的参数是intValue的拷贝,对拷贝的修改对原值intValue没有影响.
第一个输出10和上面是一个道理.
第三个输出1234.由于String是类类型, str是stringValue的地址拷贝,参数str指向的地址和stringValue的一致,但在函数changeString 中,由于String的特殊性, str=“5555”和str=new String(“5555”)是等价的, str指向了新的”5555”所在的地址,此句后str就与原来的stringValue彻底脱离了联系.
第四个输出Member?name=Douglas?age=45的道理和上面相同.
第五个输出Member?name=Andy?age=20是因为changeMemberField函数中修改了参数member 的值,也就是修改member指向实例的值,而这个实例正是member指向的值,因此member就变成了name=Andy 且age=20.

结论

Java中参数传递的都是值,对应基本类型,传递的是原值的拷贝;对于类类型,传递的是引用即地址的拷贝.
对于函数对参数的改变是否会影响原值的问题:值类型自然不会影响到原值.而对于类类型要看改变的是参数的地址还是值,如果是前者,参数和原引用指向了不同的地址,它们自然脱离了关系;如果是后者,修改的实例就是原引用指向的实例,这当然对原值进行了修改.




java的数据类型分为两种:基本类型和引用类型。
引用类型分为下面几种:类类型(class,interface,enum,annotation)和数组类型


java数据类型图:
                                ┏数值型━┳━整数型:byte short int long
              ┏基本数据类型━━┫              ┗━浮点型:float do
              ┃                ┣字符型:char                                          
数据类型╋                      ┗布尔型:boolean             
              ┃                ┏类(class)
              ┗引用数据类型━━╋接口(interface)
                                ┗数组(array)        

数组是引用类型,创建的是对象,如:int[] a = new int[5];则说明a是int型数组对象。其实“一切皆对象”。        




参考文章:

http://blog.csdn.net/jackson__qi/article/details/7982762


java数据存储的介绍,百度文库的
http://wenku.baidu.com/view/8c66da7e27284b73f2425056.html




目录
相关文章
|
2月前
|
Java
让星星⭐月亮告诉你,jdk1.8 Java函数式编程示例:Lambda函数/方法引用/4种内建函数式接口(功能性-/消费型/供给型/断言型)
本示例展示了Java中函数式接口的使用,包括自定义和内置的函数式接口。通过方法引用,实现对字符串操作如转换大写、数值转换等,并演示了Function、Consumer、Supplier及Predicate四种主要内置函数式接口的应用。
28 1
|
3月前
|
Java
java基础(11)函数重载以及函数递归求和
Java支持函数重载,即在同一个类中可以声明多个同名方法,只要它们的参数类型和个数不同。函数重载与修饰符、返回值无关,但与参数的类型、个数、顺序有关。此外,文中还展示了如何使用递归方法`sum`来计算两个数之间的和,递归的终止条件是当第一个参数大于第二个参数时。
34 1
java基础(11)函数重载以及函数递归求和
|
2月前
|
Java 编译器 C语言
【一步一步了解Java系列】:Java中的方法对标C语言中的函数
【一步一步了解Java系列】:Java中的方法对标C语言中的函数
26 3
|
4月前
|
Java 调度 Android开发
Android经典实战之Kotlin的delay函数和Java中的Thread.sleep有什么不同?
本文介绍了 Kotlin 中的 `delay` 函数与 Java 中 `Thread.sleep` 方法的区别。两者均可暂停代码执行,但 `delay` 适用于协程,非阻塞且高效;`Thread.sleep` 则阻塞当前线程。理解这些差异有助于提高程序效率与可读性。
85 1
|
5月前
|
存储 Java 编译器
Java中ArrayList的常用函数
确切地说,`ArrayList` 提供的这些方法构成了一套强大并且灵活的工具集,可以满足各种程序设计情况中的需求。例如,通过使用 `iterator()`方法,开发者可以在不知道集合大小的情况下遍历集合中全部或部分元素;而 `sort()`方法则能够对集合中的元素进行排序。这些函数在日常的Java编程中极其常见且重要,掌握它们对于进行集合操作和数据处理来说是基础且必须的。
36 2
Java中ArrayList的常用函数
|
4月前
|
存储 运维 Java
函数计算产品使用问题之怎么配置定时触发器来调用Java函数
函数计算产品作为一种事件驱动的全托管计算服务,让用户能够专注于业务逻辑的编写,而无需关心底层服务器的管理与运维。你可以有效地利用函数计算产品来支撑各类应用场景,从简单的数据处理到复杂的业务逻辑,实现快速、高效、低成本的云上部署与运维。以下是一些关于使用函数计算产品的合集和要点,帮助你更好地理解和应用这一服务。
|
4月前
|
开发框架 Java Android开发
JNI中调用Java函数
JNI中调用Java函数
30 0
|
4月前
|
开发框架 Java Android开发
JNI中调用Java函数
JNI中调用Java函数
35 0
|
4月前
|
存储 安全 Java
在 Java 中如何将 ArrayList 作为参数传递
【8月更文挑战第23天】
203 0
|
5月前
|
Rust Cloud Native Java
Java演进问题之Serverless应用或函数的冷启动如何解决
Java演进问题之Serverless应用或函数的冷启动如何解决