Python与C储存方式的区别

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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后再次研究,这对学习的效率会提高更多。

 



以上是关于Python与C储存方式的区别的主要内容,如果未能解决你的问题,请参考以下文章

C语言中静态库和动态库的区别,如何使用它们

总结几点C/C++Java与Python的区别

python2与python3的区别

sql之储存过程与函数的区别

深拷贝和浅拷贝的区别?

C++ Map中的数据存储方式是啥?Map和HashMap有啥区别?