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 ...
随机推荐
- Redis之品鉴之旅(四)
发布订阅,简单场景下的发布订阅完全可以使用. 可以简单的理解,将一个公众号视为发布者,关注公众号的人视作订阅者,公众号发布一条文章或者消息,凡事订阅公众号的都可以收到消息.一个人可以订阅多个公众号,一 ...
- redis无法连接
Exception in thread "main" redis.clients.jedis.exceptions.JedisDataException: DENIED Redi ...
- Kubernetes client-go Indexer / ThreadSafeStore 源码分析
Kubernetes client-go Indexer / ThreadSafeStore 源码分析 请阅读原文:原文地址 Contents 概述 Indexer 接口 ThreadSafe ...
- [RabbitMQ]下载&安装
RabbitMQ是基于Erlang语言开发的消息中间件,所以使用RabbitMQ需要安装Erlang和RabbitMQ两个软件. 1 Erlang 1.1 下载 官网下载地址:https://www. ...
- Python异常代码含义对照表
Python常见的异常提示及含义对照表如下: 异常名称 描述 BaseException 所有异常的基类 SystemExit 解释器请求退出 KeyboardInterrupt 用户中断执行(通常是 ...
- linux 安装libreOffice
linux 安装libreOffice 第一种方式:通过yum install libreoffice* 安装,但在使用docx文档转化为pdf的过程中,发现有些表格样式出现变形,因此采用如下方式安装 ...
- android和IOS自动化定位方法
元素定位 方法:id定位,name定位(text定位),class_name定位, accessibility_id定位,xpath定位等 (目前1.5版本的已经不支持name定位了),所以APP的定 ...
- 面试官:Java从编译到执行,发生了什么?
面试官:今天从基础先问起吧,你是怎么理解Java是一门「跨平台」的语言,也就是「一次编译,到处运行的」? 候选者:很好理解啊,因为我们有JVM. 候选者:Java源代码会被编译为class文件,cla ...
- Vulnhub实战-Dockhole_2靶机👻
Vulnhub实战-Dockhole_2靶机 靶机地址:https://www.vulnhub.com/entry/darkhole-2,740/ 1.描述 hint:让我们不要浪费时间在蛮力上面! ...
- Go语言核心36讲(Go语言进阶技术一)--学习笔记
07 | 数组和切片 我们这次主要讨论 Go 语言的数组(array)类型和切片(slice)类型. 它们的共同点是都属于集合类的类型,并且,它们的值也都可以用来存储某一种类型的值(或者说元素). 不 ...