python-变量&底层存储原理
1、变量
1、变量如何使用
1.什么是变量?
即变化的量,用于记录事物的某种状态(模仿人类事物记忆能力)
2.如何使用变量
'''日常生活中:
name: HammerZe
age: 18
hobby: basketball
程序中:
username = 'HammerZe'
age = 18
hobby = 'basketball'
'''
#语法格式:变量名 赋值符号 变量值
eg:username = 'HammerZe'
注.'='不是等号,是赋值符号!
2、变量存储的原理 --[ 重点 ]
Python的变量,粗放来说有数值型,布尔型,字符串类型,列表,元组,字典等6大类。那么不同变量类型在底层是如何存储的,关系到变量的引用,能否正确的掌握变量的相关操作?
其实变量存储的过程中,底层的存储过程并不难理解。下面用python举个例子:
name = '张三'
print(name)
'''
1.在内存中首先申请一块空间存储'张三'
2.将'张三'所在的内存空间地址绑定给name
3.如果访问输出'张三'就要通过name访问
'''
图示如下:
3、变量存储要遵循印射关系
印射关系非常好理解,就拿娶媳妇来说,当然是一夫一妻制,不能一夫多妻!
变量印射也是这样
#实例如下:
age = 18
age = 20
print(age) #这样18就会被当成垃圾pass掉,最后输出20
图示如下:
类比刚才的例子对比一下:
但是但是,女孩子可以‘养鱼’了,就是你想的那个样子我把字体搞小省的挨揍!
图示如下:
这样就是完全可以的!类比刚才的例子:
这样相比明白存储的原理了吧!
4、变量三要素
- 变量的值
- 变量的内存地址
- 变量的数据类型
这里用到几个小方法:
#实例如下:
name = 'HammerZe'
print(name) #变量的值
print(id(name)) #变量的内存地址
print(type(name)) #变量的数据类型
2、常量
主要用于记录一些不变的状态
在python中没有实际意义上的常量,都可以称为变量,但是我们墨守成规的将全大写的变量看成是常量。
#实例如下:
HOST = '127.0.0.1'
其他编程语言存在常量,定义了就无法修改!
const pi = 3.14 # 定义常量
pi = 4 # 不支持修改
3、底层优化
当数据量很小的时候,如果有多个变量名需要使用,那么就会指向同一块地址!
印射关系:一个变量名只能指向一个内存地址,一个内存地址可以有多个变量名指向(上面的一夫一妻制!)
#实例如下:
4、垃圾回收机制
Python的内存管理机制可以从以下三个方面来讲,Python垃圾回收主要以引用计数为主,分代回收为辅。
- 引用计数
- 标记清除
- 分代回收
1. 引用计数
内存中变量值身上有几个变量名绑定引用计数就是几,只要不为0就不是垃圾
2. 标记清除
当内存即将沾满的时候 python会自动暂停程序的执行 从头到尾将内存中数据进行扫描,并打上标记,之后一次性清除掉标记的数据
3. 分代回收
会将数据的监管分为三个层次,随着层级的下降监督的频率降低
最后给大家分享一个官网学习网站,一起从小白成长成大牛,欢迎学习交流并指正错误,卷起来:
[Learn PyCharm]https://www.jetbrains.com/pycharm/learn/
python-变量&底层存储原理的更多相关文章
- HBase底层存储原理
HBase底层存储原理——我靠,和cassandra本质上没有区别啊!都是kv 列存储,只是一个是p2p另一个是集中式而已! 首先HBase不同于一般的关系数据库, 它是一个适合于非结构化数据存储的数 ...
- Protobuf底层存储原理
参考官网, 序列化原理 底层二进制存储 message Test1 { optional int32 a = 1; } 并设置为a=150,序列化到一个文件中,查看文件,得到下面的二进制: 08 96 ...
- python 封装底层实现原理
事实上,python封装特性的实现纯属"投机取巧",之所以类对象无法直接调用私有方法和属性,是因为底层实现时,python偷偷改变了它们的名称. python在底层实现时,将它们的 ...
- PythonStudy——Python字典底层实现原理 The underlying implementation principle of Python dictionary
在Python中,字典是通过散列表或说哈希表实现的.字典也被称为关联数组,还称为哈希数组等.也就是说,字典也是一个数组,但数组的索引是键经过哈希函数处理后得到的散列值.哈希函数的目的是使键均匀地分布在 ...
- HBase底层存储原理——我靠,和cassandra本质上没有区别啊!都是kv 列存储,只是一个是p2p另一个是集中式而已!
理解HBase(一个开源的Google的BigTable实际应用)最大的困难是HBase的数据结构概念究竟是什么?首先HBase不同于一般的关系数据库,它是一个适合于非结构化数据存储的数据库.另一个不 ...
- Redis数据的底层存储原理
redis底层是用什么结构来存储数据的呢? 我们从源码上去理解就会容易的多: redis底层是使用C语言来编写的,我们可以看到它的数据结构声明.一个 dict 有两个dictht,一个dictht ...
- python列表底层实现原理
Python 列表的数据结构是怎么样的? 书上说的是:列表实现可以是数组和链表.顺序表是怎么回事?顺序表一般是数组. 列表是一个线性的集合,它允许用户在任何位置插入.删除.访问和替换元素.列表实现是基 ...
- 列式数据库~clickhouse 底层存储原理
简介:今天介绍列式数据库的一些基本原理 一 数据目录 Data目录 数据存储目录,数据按照part分成多个文件夹,每个文件夹下存储相应数据和对应的元信息文件 Metadata 表定义语句,存储所有表 ...
- python入门3 python变量,id(),is运算符
python变量无需声明数据类型,可以直接赋值使用. 比如: num=100 #整数 str="字符串" #字符串 turple1 =('mon','tue','wed','thu ...
随机推荐
- IdentityServer4[2]:启动一个新的IdentityServer项目
启动一个新的IdentityServer项目 从头开始,从基础开始,然后变得更加复杂,循序渐进的学习 工具:VS2017 15.9.8 .Net Core2.2 基本过程 创建一个新的ASP.NET ...
- 使用Stargate访问K8ssandra,Springboot整合Cassandra
1 简介 之前我们在文章<K8ssandra入门-详细记录在Linux上部署K8ssandra到Kubernetes>成功地在Ubuntu上安装了K8ssandra,现在我们来看看如何访问 ...
- 解决安装mysql 到start service出现未响应问题
mysql下载地址 链接: https://pan.baidu.com/s/1vYpsNkVjUHqOKPQl9Y9A9A 提取码: wngn 安装可以参考 今天下载了MySql5.5,没想到的是前面 ...
- JVM学习笔记——GC垃圾收集器
GC 垃圾收集器 Java 堆内存采用分代回收算法,因此 JVM 针对新生代和老年代提供了多种垃圾收集器. 1. Serial 收集器 Serial 收集器是单线程收集器,采用复制算法. 是最基本的垃 ...
- 创业公司用 Serverless,到底香不香?
作者 | Mike Butusov 来源 | Serverless 公众号 在过去的 5 年里,使用云厂商处理应用后台的流行程度大幅飙升.其一,初创企业主采用 Serverless 方式,以节省基础设 ...
- modal框
modal框 创建modal款的基本"框架": 1 <body> 2 <!--1.触发模态框的按钮--> 3 <button class=" ...
- Python实现九九乘法表
- 听说,99% 的 Go 程序员都被 defer 坑过
原文链接: 听说,99% 的 Go 程序员都被 defer 坑过 先声明:我被坑过. 之前写 Go 专栏时,写过一篇文章:Go 专栏|错误处理:defer,panic 和 recover.有小伙伴留言 ...
- 分布式/微服务必配APM系统,SkyWalking让你不迷路
前言 如今分布式.微服务盛行,面对拆分服务比较多的系统,如果线上出现异常,需要快速定位到异常服务节点,假如还用传统的方式排查肯定效率是极低的,因为服务之间的各种通信会让定位更加繁琐:所以就急需一个分布 ...
- NX Open 切削层加载
UF_CUT_LEVELS_load Loads the current cut levels for the specified operation into the data structure ...