Python中的函数(内置函数和我们自己编写的自定义函数)是处理数据的关键工具。但是他们对我们的数据做了什么可能有点令人困惑,如果我们不知道发生了什么,它可能会在我们的分析中造成严重的错误。
在本教程中,我们将详细研究Python在函数中处理不同数据类型时是如何对它们进行操作的,并学习如何确保只有在希望更改数据时才更改数据。
函数中的内存隔离
为了理解Python如何处理函数内部的全局变量,我们来做一个小实验。我们将创建两个全局变量number_1和number_2,并为它们赋值整数 5 和 10。然后,我们将使用这些全局变量作为函数的参数来执行一些简单的数学运算。我们还将使用变量名作为函数的参数名。然后,我们将查看函数中所有变量的使用是否影响了这些变量的全局值。
正如我们在上面看到的,函数正常运行,全局变量number_1和number_2的值没有变化,尽管我们在函数中使用它们作为形参和实参名。这是因为Python将函数中的变量存储在与全局变量不同的内存位置。它们是被隔离的。因此,变量number_1可以在全局中有一个值(5),而在函数内部有一个不同的值(50),在这个函数中它是独立的。
(顺便说一句,如果你对parameters(形参) 和 arguments(实参)之间的区别感到困惑,Python文档中关于这个主题的内容非常有用。)
那么列表和字典呢?
列表
我们已经看到,我们在函数内部对上面的number_1这样的变量所做的操作并不影响它的全局值。但是number_1是一个整数,这是一个非常基本的数据类型。如果我们用不同的数据类型(比如列表)尝试相同的实验,会发生什么?下面,我们将创建一个名为duplicate_last() 的函数,它将复制我们作为参数传递的任何列表中的最终条目。