Python与C储存方式的区别

在Alex视频课程中得知Python中:

a=2

b=a

a=3

该过程中的内存储存方式为:

1、先再内存中开栈存储2这个数据的空间

2、a指向数据为2的内存空间地址

3、b=a 此时b指向2的内存空间的地址

4、a=3 内存中开栈存储3这个数据的空间

5、此时a=3中,a重新指向数据为3的内存地址

总结:Python是动态语言,变量只是对象的引用

并在VC中作简单的测试

int i=1;
int y=i;
i=2;

在调试过程中得知

int i=1;            mov     dword ptr [ebp-4],1    //可以看出 当i=1赋值时候,在内存开栈,把1存入相应地址中

int y=i;            mov      eax,dword ptr [ebp-4]    //此时先把内存地址中的数据赋值给累加器eax

                      mov      dword ptr [ebp-8],eax    //再把累加器中的数据赋值给y的地址中

i=2;                mov      dword ptr [ebp-4],2        //当i=2重新赋值的时候,就把2赋值给i原来的地址中

后来通过网上查阅得知

因为动态语言Python不同于静态语言C,其变量只是对象的引用

这其实是十分基本的问题,通过查阅Python的解释器的工作原理知道原因。只是第一次接触动态语言,还不是很熟悉。但是对于原理性的东西不妨先放到学完基本Python后再次研究,这对学习的效率会提高更多。

原文地址:https://www.cnblogs.com/jasonsou/p/7599420.html