今天看《java 核心 卷1》的时候,作者提到了函数传参的问题,他提到,java传参,传的是值,而不是引用,然后,函数将要传的实参的值(如果实参是基本数据类型,那么就是值。如果实参是对象,则是内存地址)拷贝之后,赋予形参,然后,对形参进行操作。如果是8个基本类型,那么无论如何操作,都不会对原来的实参产生影响。如果要传的实参是对象,由于原来的实参和形参都是指向的同一个对象,所以,所有对形参的操作都将作用到原来的东西上,但是如果对形参进行了重新赋值,那么只是改变了形参的指向,那么将不会在对原来的实参产生影响。


public class ArgDemo {
public static void improve(int x,int y){
System.out.println(x); //10
System.out.println(y); //10
x += 10;
y += 20;
System.out.println(x); //20 这是在a b 的副本,x y上的操作。函数结束,就释放了
System.out.println(y); //30 }
public static void main(String[] args){
int a = 10 ;
int b = 10 ;
improve(a,b);
System.out.println(a); //10
System.out.println(b);//10
}
} public class ArgDemo {
public static void change(String x,String y){
System.out.println(x); //hello
System.out.println(y); //world
String temp = x;
x = y;
y = temp;
System.out.println(x); //world//这里 x,y 的值已经发生了改变,如果穿的是参数(或者是如果传的是对象本身)的话,那么main函数里面的
System.out.println(y); //hello // 的x,y 也应该发生了改变。。事实是是没有变化的,这里操作的是a和b的副本。
zhixiang
}
public static void main(String[] args){
String a = "hello" ;
String b = "world" ;
change(a,b);
System.out.println(a); //hello //这里和刚传进去的形参是一样的,且和原来一样,所以说,形参是 它们的副本。
System.out.println(b); //world
} }

并给出了结论:

1、一个方法不能修改一个基本数据类型的参数(数值型或布尔型)

2、一个方法可以改变一个对象参数的状态(相当于在对象修改自身)

3、一个方法不能让对象参数引用一个新的对象(相当于对参数也就是副本进行了重新赋值,这仅会影响参数的的指向,而不会影响实参的的指向)

我想到了Python中的传参问题,Python中一切皆对象。

a = [1,2,3]
b = [1,2,5] print("bef a ================ "+str(id(a)))#140286697654752
print("bef b ================ "+str(id(b)))#140286697655760
def change(x,y):
print("x ======== "+ str(id(x)))# 140286697654752
print("y ======== "+ str(id(y)))#140286697655760
temp = x #这里采用笨方式进行x,y的交换
x = y
y = temp
print("x aft============= "+ str(id(x)))#140286697655760
print("y aft============= "+ str(id(y)))#140286697654752 change(a,b) print(a)#[1, 2, 3]
print("bef a ================ "+str(id(a)))#140286697654752
print("bef b ================ "+str(id(b)))#140286697655760
print(b)#[1, 2, 5] ############################################################################ a = "zmu"
b = "muzdda" print("bef a ================ "+str(id(a)))#139816005403104
print("bef b ================ "+str(id(b)))#139816005403152
def change(x,y):
print("x ======== "+ str(id(x)))# 139816005403104
print("y ======== "+ str(id(y)))#139816005403152
temp = x #
x = y
y = temp
print("x aft============= "+ str(id(x)))#139816005403152
print("y aft============= "+ str(id(y)))#139816005403104 change(a,b) print(a)#zmu
print("aft a ================ "+str(id(a)))#139816005403104
print("aft b ================ "+str(id(b)))#139816005403152
print(b)#muzdda

函数传参传的是啥的思考【java Python】的更多相关文章

  1. Java函数的传参机制

    一 最近的一个项目,里面各种返回void,参数用引用类型,那叫一个熟和多,但是也把我绕糊涂了. 我就打算好好理一理java的传参机制,整理一番 二 很多人一听Java的传参,那一定会脱口而出,java ...

  2. js动态绑定click事件时function传参问题

    今天碰到了这样一个问题,我在javascript中动态创建了一个button, 然后我想给改button添加click事件,绑定的function想要传入一个变量参数, 一开始我想直接通过函数传参传进 ...

  3. ajax 传参 乱码问题

    http://blog.csdn.net/yiyuhanmeng/article/details/7548505 开发一直用firfox网页,调试什么的都很方便.所以遇到了浏览器之间的兼容问题.url ...

  4. 再谈Java方法传参那些事

    把一个变量带进一个方法,该方法执行结束后,它的值有时会改变,有时不会改变.一开始会觉得--“好神奇呀”.当我们了解java内存分析的知识后,一切都是那么简单明了了--“哦,这么回事呀”.但是今天的上机 ...

  5. c++11中关于`std::thread`线程传参的思考

    关于std::thread线程传参的思考 最重要要记住的一点是:参数要拷贝到线程独立内存中,不管是普通类型.还是引用类型. 对于传递参数是引用类型,需要注意: 1.当指向动态变量的指针(char *) ...

  6. java调用py文件传参执行

    java执行的也是py文件主函数. 传参: String url="*********************"; String[] args1 = new String[] { ...

  7. vue 组件传参

    路由配好了 再传个参呗 注:组件信息流转的时候只能单向1 > 父子传参传参:通过属性prop:传递数据 a.父组件传参给子组件 子组件: <ul> <li v-for=&quo ...

  8. java与js交互,相互调用传参

    随着前端技术的发展与H5的广泛使用,移动端采用native+h5的方式越来越多了,对于Android来说就涉及到java与js的交互,相互调用传参等.下面就来看一下java与js交互的简单demo. ...

  9. vue路由传参并跳转页面

    在vue项目中参数的传递可以使用本地缓存或者Vuex,那么vue能不能像小程序一样路由传参呢,显然是可以的而且非常简单 方式一:query传参 //传参 go(){ that.$router.push ...

随机推荐

  1. Delphi 常用语句

    1.屏蔽Float浮点数出错: Set8087CW(Longword($133f)); 2.Idhttp参数设置: FIdhttp                  := TIdHTTP.Create ...

  2. (转)Floyd算法

    原文地址:http://www.cnblogs.com/twjcnblog/archive/2011/09/07/2170306.html 参考资料:http://developer.51cto.co ...

  3. ElasticSearch Java API

    ElasticSearch-Java Client类型 ElasticSearch-TransportClient环境准备 ElasticSearch-TransportClient连接 Elasti ...

  4. Koa快速入门教程(一)

    Koa 是由 Express 原班人马打造的,致力于成为一个更小.更富有表现力.更健壮的 Web 框架,采用了async和await的方式执行异步操作. Koa有v1.0与v2.0两个版本,随着nod ...

  5. Centos7使用pxe安装KVM虚拟机

    Centos7使用pxe安装KVM虚拟机 一.安装服务所需的软件 [root@localhost ~]yum install nginx dhcp vsftpd syslinux -y [root@l ...

  6. sql server 给表加说明,给列/字段加说明

    --sql server给表加说明: --banner EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'Banner ...

  7. JDK 8 中Lambda表达式的使用

    认识Lambda表达式 首先来引入一个示例 new Thread(new Runnable() {     @Override     public void run() {         Syst ...

  8. tpc资料汇总

    官方资料 TPC官网  http://www.tpc.org/ 配置文档 大家一起来测试,benchmark起来(MySQL下的TPC-C,TPC-H,TPC-W)  http://www.itpub ...

  9. Ruby学习笔记7: 添加身份验证(adding Authentication)

    我们已经完成了Category & Product页面内容的增删改查,再加入一个身份验证即可成为一个较完整的Rails App了.本文就来完成这个任务. We now need to give ...

  10. openStack cpu绑定

    来自:http://fishcried.com/2015-01-09/cpu_bindings/ 前一篇理解cpu topology对CPU Topology进行了学习总结,这里想总结下OpenSta ...