一、变量创建过程
首先,当我们定义了一个变量name = 'Kwan'的时候,在内存中其实是做了这样一件事:
程序开辟了一块内存空间,将'Kwan'存储进去,再让变量名name指向'Kwan'所在的内存地址。如下图所示:
我们可以通过id()方法查看这个变量在内存中的地址。
name = 'Kwan' print(id(name))
二、变量的修改
一般我们认为修改一个变量就是用新值把就旧值覆盖掉,可Python真是这么实现的么?
name = 'Kwan' print(id(name)) name = 'Kobe' print(id(name))
实际的原理是什么样的呢?程序先申请了一块内存空间来存储'Kwan',让name变量名指向这块内存空间,往下执行name = 'Kobe'之后,又申请了另一块内存空间来存储'Kobe',并让原本指向'Kwan'内存的链接断开,让name再指向'Kobe'。
三、变量的指向关系
问:下面这段代码为何出现这样的现象?
name1 = 'Kwan' name2 = name1 print(name1, name2) name1 = 'Kobe' print(name1, name2)
要想知道上面问题的结果是为什么,首先要了解再内存中两个变量的存储情况。
从上面的示意图中我们可以知道,当执行name2 = name1时,事实上时让name2指向了'Kwan'所在的内存地址。
修改name1的值,相当于断开了name1到'Kwan'的链接,重新建立name1和'Kobe'之间的链接。在这个过程中,始终没有影响到name2和'Kwan'之间的关系,因此name2还是'Kwan',而name1变成了'Kobe'。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持亿速云。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。