博客
关于我
Python中函数参数为可变对象
阅读量:508 次
发布时间:2019-03-07

本文共 405 字,大约阅读时间需要 1 分钟。

函数传值时是传递的内存地址

比如

def add(x):    print(id(x))    x = x + [1]    print(id(x))

 

定义 q = [1, 2, 3]

id(q)是 2896878141960

调用 add(q)

此时,传递的是q的地址,所以函数中第一次打印时 值为 2896878141960,而在执行x = x +1时 开辟了新的空间,而此时x也指向了新的地址,所以第二次打印时 值是 2896878325512,所以这操作对原来地址的对象没有影响

But

如果要是 对可变对象的地址直接进行操作时就会出问题,比如列表上进行 append、remove等操作

x1 = [1, 2, 3]id(x1)def add(x)    print(id(x))    x.append(1)    print(id(x))#执行add(x1)#执行结束后,x1也会发生变化

 结果:

 

 

 

转载地址:http://fcejz.baihongyu.com/

你可能感兴趣的文章
mysql /*! 50100 ... */ 条件编译
查看>>
mudbox卸载/完美解决安装失败/如何彻底卸载清除干净mudbox各种残留注册表和文件的方法...
查看>>
mysql 1264_关于mysql 出现 1264 Out of range value for column 错误的解决办法
查看>>
mysql 1593_Linux高可用(HA)之MySQL主从复制中出现1593错误码的低级错误
查看>>
mysql 5.6 修改端口_mysql5.6.24怎么修改端口号
查看>>
MySQL 8.0 恢复孤立文件每表ibd文件
查看>>
MySQL 8.0开始Group by不再排序
查看>>
mysql ansi nulls_SET ANSI_NULLS ON SET QUOTED_IDENTIFIER ON 什么意思
查看>>
multi swiper bug solution
查看>>
MySQL Binlog 日志监听与 Spring 集成实战
查看>>
MySQL binlog三种模式
查看>>
multi-angle cosine and sines
查看>>
Mysql Can't connect to MySQL server
查看>>
mysql case when 乱码_Mysql CASE WHEN 用法
查看>>
Multicast1
查看>>
mysql client library_MySQL数据库之zabbix3.x安装出现“configure: error: Not found mysqlclient library”的解决办法...
查看>>
MySQL Cluster 7.0.36 发布
查看>>
Multimodal Unsupervised Image-to-Image Translation多通道无监督图像翻译
查看>>
MySQL Cluster与MGR集群实战
查看>>
multipart/form-data与application/octet-stream的区别、application/x-www-form-urlencoded
查看>>