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后再次研究,这对学习的效率会提高更多。

时间: 2024-11-11 21:04:12

Python与C储存方式的区别的相关文章

关系型数据库与HBase的数据储存方式区别

如今Bigtable型(列族)数据库应用越来越广,功能也很强大.但是很多人还是把它当做关系型数据库在使用,用原来关系型数据库的思维建表.存储.查询.本文以hbase举例讲述数据模式的变化. 传统关系型数据库(mysql,oracle)数据存储方式主要如下: 图一 上图是个很典型的数据储存方式,我把每条记录分成3部分:主键.记录属性.索引字段.我们会对索引字段建立索引,达到二级索引的效果. 但是随着业务的发展,查询条件越来越复杂,需要更多的索引字段,且很多值都不存在,如下图: 图二 上图是6个索

python 多线程和C++多线程的区别

看到论坛上有人问python多线程和C++多线程的区别? 暖神是这样回答的: Python有Global Interpreter Lock,所以嘛……你懂的.C++11开始才有多线程,使用共享内存方式的线程间通信,有低级的atomic operation和memory order,以及高级的lock, condition的,却没有提供消息队列. 然后,就去找GIL(Global Interpreter Lock)的定义,下面有一个定义,wiki的定义是这样的.在stackoverflow上看到了

PHP中常用的超全局变量 表单中get和post提交方式的区别 session与cookie的区别 GD库是做什么用的

PHP中常用的超全局变量 $_GET ----->get传送方式$_POST ----->post传送方式$_REQUEST ----->可以接收到get和post两种方式的值$GLOBALS ----->所有的变量都放在里面$_FILES ----->上传文件使用$_SERVER ----->系统环境变量$_SESSION ----->会话控制的时候会用到$_COOKIE ----->会话控制的时候会用到 表单中get和post提交方式的区别 get是把参

quartz储存方式之JDBC JobStoreTX

这篇单单记录一下个人配置使用quartz的JDBC JobStoreTX的过程以及其中遇到的问题,这里的quartz是version2.2.1,数据库使用的MySQL. JDBCJobStore储存是速度比较慢的,但是也不至于很坏,通过JDBCJobStore储存于数据库的方式适用于Oracle,PostgreSQL, mysql, MS SQLServer, HSQLDB, DB2等数据库. 1) 建表 在下载的文件的docs/dbTables目录下有对应建表语句,如果没有对应于应用的就自己改

Python浅拷贝copy()与深拷贝deepcopy()区别

其实呢,浅拷贝copy()与深拷贝deepcopy()之间的区分必须要涉及到python对于数据的存储方式. 首先直接上结论: -–我们寻常意义的复制就是深复制,即将被复制对象完全再复制一遍作为独立的新个体单独存在.所以改变原有被复制对象不会对已经复制出来的新对象产生影响. -–而浅复制并不会产生一个独立的对象单独存在,他只是将原有的数据块打上一个新标签,所以当其中一个标签被改变的时候,数据块就会发生变化,另一个标签也会随之改变.这就和我们寻常意义上的复制有所不同了. 对于简单的 object,

浅拷贝与深拷贝的实现方式、区别;deepcopy如果你来设计,如何实现(一)

浅拷贝与深拷贝的实现方式.区别:deepcopy如果你来设计,如何实现: copy浅拷贝:没有拷贝子对象,所以原始数据改变,子对象改变 deepcopy深拷贝:包含对象里面的子对象的拷贝,所以原始对象的改变不会造成深拷贝里的任何子元素的改变 Python里的赋值符号"="只是将对象进行了引用,如果想新开辟进行了引用,如果想新开辟地址new出一个新对象,要用copy模块里copy.copy(),但是用这个方法得到的对象就是新对象,但是数据还是引用. 如果要完全得到一个一模一样的对象,要用

Python form...import...和import的区别(自己理解的)

Python有两种导入包和模块的方式,区别如下 form...import... import 相对导包 导入不同包子模块 可以导入模块所需变量/函数/类   init文件的__all__特殊变量(模块列表)               import 语句 import_stmt ::= "import" module ["as" identifier] ("," module ["as" identifier])* | &q

5.Python里面match()和search()的区别?

Python里面match()和search()的区别? '''match()从第一个字符开始找,如果第一个就不匹配,会直接返回None,不继续匹配.主要用于匹配开头''' #coding=utf-8 import re result = re.match("www","www.cn") result.group() >>'www' # 否则返回None '''search()会在整个字符串中查找,知道找到一个匹配的''' #coding=utf-8 i

虚拟机NetworkAdapter三种方式的区别

虚拟机在安装时默认的有三块网卡,VMnet1和VMnet8,另外还有VMnet0 Vmware 还提供了三种网络连接模式: 分别为: A 桥接bridge  B NAT 网络地址转换 C  主机模式 下面来简单说一下 三种方式的区别  : 1) bridge : 默认使用VMnet0,不提供DHCP服务 在桥接模式下,虚拟机和宿主计算机处于同等地位,虚拟机就像是一台真实主机一样存在于局域网中.因此在桥接模式下,我们就要像对待其他真实计算机一样为其配置IP.网关.子网掩码等等.当我们可以自由分配局