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 ...
随机推荐
- 好未来数据中台 Node.js BFF实践(一):基础篇
好未来数据中台 Node.js BFF实践系列文章列表: 基础篇 实战篇(TODO) 进阶篇(TODO) 好未来数据中台的Node.js中间层从7月份开始讨论可行性,截止到9月已经支持了4个平台,其中 ...
- Erase-Remove 惯用法
看到<Effective STL>条款 9 的时候想到了我以前复习的"如何正确使用迭代器删除元素",我面试时使用的也是里面的方法,看面试官的反应好像也没有什么问题,还问 ...
- Linux从头学15:【页目录和页表】-理论 + 实例 + 图文的最完全、最接地气详解
作 者:道哥,10+年嵌入式开发老兵,专注于:C/C++.嵌入式.Linux. 关注下方公众号,回复[书籍],获取 Linux.嵌入式领域经典书籍:回复[PDF],获取所有原创文章( PDF 格式). ...
- linux主机互信操作
一.主机互信原理两个主机之间ssh登录需要提示输入对方的密码,当频繁需要登录操作时,可以通过linux公钥和秘钥,建立双机信任关系.把你源主机的公钥文件内容追加到目的主机对应用户下的authorize ...
- 题解 2020.10.24 考试 T2 选数
题目传送门 题目大意 见题面. 思路 本来以为zcx.pxj变强了,后来发现是SPJ出问题了...考试的时候感觉有点人均啊...结果自己还是只想出来一半. 我们假设 \(f(x)=(\lfloor\f ...
- MyBatis 中两表关联查询MYSQL (14)
MyBatis 中两表关联查询MYSQL 1.创建数据库表语句 2.插入测试数据 3.pom文件内容 <?xml version="1.0" encoding="U ...
- python的参数传递是值传递还是引用传递?都不是!
[写在前面] 参考文章: https://www.cnblogs.com/spring-haru/p/9320493.html[偏理论,对值传递和引用传递作了总结] https://www.cnblo ...
- 【UE4 C++ 基础知识】<2> UFUNCTION宏、函数说明符、元数据说明符
UFunction声明 UFunction 是虚幻引擎4(UE4)反射系统可识别的C++函数.UObject 或蓝图函数库可将成员函数声明为UFunction,方法是将 UFUNCTION 宏放在头文 ...
- UI自动化测试之Airtest
官方文档: https://airtest.doc.io.netease.com/ 本文我们讲解下Airtest的使用,主要学习目标有以下几点: (1)认识Airtest (2)了解Airtest能做 ...
- Linux下有用的命令
ldd 查看依赖的动态库 加上-r可以查看未定的符号 c++ filt 通过编译换名后的函数名查找某经过编译器换名前的函数名 csh 切换c shell source .chsrc 可以刷新环境变量 ...