您的位置:首页 > 编程语言 > Python开发

小猿圈python学习-变量创建过程

2019-05-05 09:48 288 查看

变量创建过程

首先,当我们定义了一个变量name = ‘oldboy’的时候,在内存中其实是做了这样一件事:

程序开辟了一块内存空间,将‘oldboy’存储进去,再让变量名name指向‘oldboy’所在的内存地址。如下图所示:

我们可以通过id()方法查看这个变量在内存中的地址

name = “oldboy”
id(name)
4317182304
变量的修改
一般我们认为修改一个变量就是用新值把旧值覆盖掉, 可python是这样实现的么?

name = “oldboy”
id(name)
4317182304

name = “alex”
id(name) # 如果只是在原有地址上修改,那么修改后内存地址不应该变化呀。
4317182360
实际的原理什么样的呢? 程序先申请了一块内存空间来存储‘oldboy’,让name变量名指向这块内存空间

执行到name=‘alex’之后又申请了另一块内存空间来存储‘alex’,并让原本指向‘oldboy’内存的链接断开,让name再指向‘alex’。

变量的指向关系

提问:下面这段代码为何出现这样的现象?

name1 = ‘oldboy’
name2 = name1 # 把name1赋值给name2,这样name2的值也是oldboy了
print(name1,name2)
oldboy oldboy

name1 = ‘alex’
print(name1,name2) #改了name1后,name2为何没跟着改?
alex oldboy
要想知道上面问题的结果是为什么,首先要了解在内存中两个变量的存储情况

从上面的示意图中我们可以知道,当执行name2=name1这句话的时候,事实上是让name2指向了‘oldboy’所在的内存地址。

修改name1的值,相当于断开了name1到‘oldboy’的链接,重新建立name1和‘alex’之间的链接。在这个过程中,始终没有影响到name2和‘oldboy‘之间的关系,因此name2还是‘oldboy’,而name1变成了‘alex’。

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: