python进行参数传递的方法


Posted in Python onMay 12, 2020

在分析python的参数传递是如何进行的之前,我们需要先来了解一下,python变量和赋值的基本原理,这样有助于我们更好的理解参数传递。

python变量以及赋值

  • 数值

从几行代码开始

In [1]: a = 1
In [2]: b = a
In [3]: a = a + 1

我们先将1赋值给a,也就是a指向了1这个对象,在python中一切皆对象。接着b=a,则表示让b也指向了1这个对象,python中一个对象是可以被多个引用所指向。最后执行的a=a+1,这里需要注意一点,python的数据类型中如int、str等不可变类型,执a=a+1这种操作,并不是把a指向的对象的值增加1,而是生成一个新的对象2,并让a指向2这个对象,原来的对象还存在于内存中。那这里的话还是会被指向,我们来分别看一下a和b的值:

In [4]: a
Out[4]: 2

In [5]: b
Out[5]: 1

通过这个例子你可以看到,这里的 a 和 b,开始只是两个指向同一个对象的变量而已,或者你也可以把它们想象成同一个对象的两个名字。简单的赋值 b = a,并不表示重新创建了新对象,只是让同一个对象被多个变量指向或引用。同时,指向同一个对象,也并不意味着两个变量就被绑定到了一起。如果你给其中一个变量重新赋值,并不会影响其他变量的值。

  • 列表

还有一个列表的例子,再来瞅瞅:

In [6]: l1 = [3,4,5,6]
In [7]: l2 = l1
In [10]: l1.append(7)
In [11]: l1
Out[11]: [3, 4, 5, 6, 7]
In [12]: l2
Out[12]: [3, 4, 5, 6, 7]

代码中,我们让l1和l2这两个变量都指向了[3,4,5,6]这个对象,我们知道列表是一种可变的数据结构,所以append操作并不会产生新的对象,只是在末尾添加了一个元素,变成了[3, 4, 5, 6, 7],由于 l1 和 l2 同时指向这个列表,所以列表的变化会同时反映在 l1 和 l2 这两个变量上,那么,l1 和 l2 的值就同时变为了[3, 4, 5, 6, 7]。

  • 对象删除

python中变量是可以删除的,但是对象是没办法删除的

In [22]: a = [1,4,5]
In [23]: del a

del语句删除a这个变量,就无法通过a访问[1,4,5],但是这个对象在存在中还是存在的,python的垃圾回收机制发现引用为0的时候就会把它回收掉。

  • 总结
  1. 变量的赋值,只是表示让变量指向了某个对象,并不表示拷贝对象给变量;而一个对象,可以被多个变量所指向
  2. 可变对象(列表,字典,集合等等)的改变,会影响所有指向该对象的变量
  3. 对于不可变对象(字符串、整型、元组等等),所有指向该对象的变量的值总是一样的,也不会改变。但是通过某些操作(+= 等等)更新不可变对象的值时,会返回一个新的对象

变量可以被删除,但是对象无法被删除

python函数是如何进行参数传递的

python的参数传递是赋值传递或者说是引用传递,python里一切皆对象,所以参数传递时,只是让新变量与原变量指向了同一个对象,下面我们来看个例子:

In [28]: def func(b):
  ...:   b = 2
In [29]: a = 1
In [30]: func(a)
In [31]: a
Out[31]: 1

这里的参数传递,使变量 a 和 b 同时指向了 1 这个对象。但当我们执行到 b = 2 时,系统会重新创建一个值为 2 的新对象,并让 b 指向它;而 a 仍然指向 1 这个对象。所以,a 的值不变,仍然为 1。

如何改变a的值呢?

我们可以在函数中将b返回

def func(b):
  b = 2
  return b
a = 1
a = func(a)
a
2

上面的例子我们的是int类型的,下面我们看一下列表的例子:

def func(l2):
  l2.append(77)

l1 = [12,3,6]
func(l1)
l1
[12,3,6,77]

这里 l1 和 l2 先是同时指向值为[1, 2, 3]的列表。不过,由于列表可变,执行 append() 函数,对其末尾加入新元素 4 时,变量 l1 和 l2 的值也都随之改变了.

那大家看一下面的例子,结果是什么呢?

def func(l2):
  l2 = l2 + [4]

l1 = [12,3,6]
func(l1)
l1
[12,3,6]

可以看到,l1没有发生变化,原因是l2 + [4]这个操作表示创建了一个末尾加入元素 4的新列表,并让 l2 指向这个新的对象,l1还是指向原有的对象。

总结

今天,我们讨论了 Python 的变量及其赋值的基本原理,并且解释了 Python 中参数是如何传递的。和其他语言不同的是,Python 中参数的传递既不是值传递,也不是引用传递,而是赋值传递,或者是叫对象的引用传递。需要注意的是,这里的赋值或对象的引用传递,不是指向一个具体的内存地址,而是指向一个具体的对象。

以上就是python进行参数传递的方法的详细内容,更多关于python如何进行参数传递的的资料请关注三水点靠木其它相关文章!

Python 相关文章推荐
Django与遗留的数据库整合的方法指南
Jul 24 Python
python编写Logistic逻辑回归
Dec 30 Python
python http接口自动化脚本详解
Jan 02 Python
python基础教程项目四之新闻聚合
Apr 02 Python
python根据list重命名文件夹里的所有文件实例
Oct 25 Python
python selenium firefox使用详解
Feb 26 Python
python 自动轨迹绘制的实例代码
Jul 05 Python
TensorFlow绘制loss/accuracy曲线的实例
Jan 21 Python
解决Keras中CNN输入维度报错问题
Jun 29 Python
Python map及filter函数使用方法解析
Aug 06 Python
python 批量下载bilibili视频的gui程序
Nov 20 Python
Python开发工具Pycharm的安装以及使用步骤总结
Jun 24 Python
python输出数学符号实例
May 11 #Python
使用matlab 判断两个矩阵是否相等的实例
May 11 #Python
Django models文件模型变更错误解决
May 11 #Python
对Matlab中共轭、转置和共轭装置的区别说明
May 11 #Python
Django静态资源部署404问题解决方案
May 11 #Python
python矩阵运算,转置,逆运算,共轭矩阵实例
May 11 #Python
Selenium元素定位的30种方式(史上最全)
May 11 #Python
You might like
简单采集了yahoo的一些数据
2007/02/14 PHP
PHP页面跳转操作实例分析(header方法)
2016/09/28 PHP
stripos函数知识点实例分享
2019/02/11 PHP
HTML页面如何象ASP一样接受参数
2007/02/07 Javascript
csdn 论坛技术区平均给分功能
2009/11/07 Javascript
为radio类型的INPUT添加客户端脚本(附加实现JS来禁用onClick事件思路代码)
2010/11/11 Javascript
JavaScript去掉数组中的重复元素
2011/01/13 Javascript
在JavaScript中实现类的方式探讨
2013/08/28 Javascript
JavaScript中的分号插入机制详细介绍
2015/02/11 Javascript
JavaScript中的Promise使用详解
2015/06/24 Javascript
React快速入门教程
2017/01/17 Javascript
xmlplus组件设计系列之树(Tree)(9)
2017/05/02 Javascript
Vue.js实例方法之生命周期详解
2017/07/03 Javascript
webpack开发跨域问题解决办法
2017/08/03 Javascript
vue2.0 实现导航守卫(路由守卫)
2018/05/21 Javascript
JS使用遮罩实现点击某区域以外时弹窗的弹出与关闭功能示例
2018/07/31 Javascript
Vue中错误图片的处理的实现代码
2019/11/07 Javascript
node使用request请求的方法
2019/12/20 Javascript
微信小程序复选框实现多选一功能过程解析
2020/02/14 Javascript
python多线程用法实例详解
2015/01/15 Python
在Django的视图中使用form对象的方法
2015/07/18 Python
Python json模块dumps、loads操作示例
2018/09/06 Python
python selenium 弹出框处理的实现
2019/02/26 Python
Django实现发送邮件功能
2019/07/18 Python
pycharm通过anaconda安装pyqt5的教程
2020/03/24 Python
利用CSS3实现的文字定时向上滚动
2016/08/29 HTML / CSS
美国婴儿用品及配件购买网站:Munchkin
2019/04/03 全球购物
迅雷Cued工作心得体会
2014/01/27 职场文书
祖国在我心中演讲稿600字
2014/09/23 职场文书
2015年宣传部部长竞选演讲稿
2014/11/28 职场文书
2014年初级职称工作总结
2014/12/08 职场文书
辛德勒的名单观后感
2015/06/03 职场文书
2015年酒店销售部工作总结
2015/07/24 职场文书
小学英语听课心得体会
2016/01/14 职场文书
vue使用v-model进行跨组件绑定的基本实现方法
2021/04/28 Vue.js
openGauss数据库JDBC环境连接配置的详细过程(Eclipse)
2022/06/01 Java/Android