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 ...
随机推荐
- 学习Tomcat(六)之类加载器
通过前面的文章我们知道,Tomcat的请求最终都会交给用户配置的servlet实例来处理.Servlet类是配置在配置文件中的,这就需要类加载器对Servlet类进行加载.Tomcat容器自定义了类加 ...
- t-SNE算法
t-SNE 算法 前言 t-SNE(t-distributed stochastic neighbor embedding) 是用于降维的一种机器学习算法,由 Laurens van der Maat ...
- 使用 grpcurl 通过命令行访问 gRPC 服务
原文链接: 使用 grpcurl 通过命令行访问 gRPC 服务 一般情况下测试 gRPC 服务,都是通过客户端来直接请求服务端.如果客户端还没准备好的话,也可以使用 BloomRPC 这样的 GUI ...
- a标签刷新当前页面
<a href="javascript:location.reload();">刷新页面</a>
- 初学Python-day11 函数4
函数 1.递归函数 自己不断调用自己的过程 2.递归求和 1 def sum(arg): 2 if arg == 1: 3 return 1 4 return arg + sum(arg - 1) 5 ...
- 【UE4 C++ 基础知识】<2> UFUNCTION宏、函数说明符、元数据说明符
UFunction声明 UFunction 是虚幻引擎4(UE4)反射系统可识别的C++函数.UObject 或蓝图函数库可将成员函数声明为UFunction,方法是将 UFUNCTION 宏放在头文 ...
- 【c++ Prime 学习笔记】第16章 模板与泛型编程
面向对象编程(OOP)和泛型编程(GP)都能处理在编写程序时类型未知的情况 OOP能处理运行时获取类型的情况 GP能处理编译期可获取类型的情况 标准库的容器.迭代器.算法都是泛型编程 编写泛型程序时独 ...
- AIApe问答机器人项目Scrum Meeting博客汇总
荡起双桨 Scrum Meeting 博客汇总 一.Alpha阶段 AIApe问答机器人Scrum Meeting 4.23 AIApe问答机器人Scrum Meeting 4.25 AIApe问答机 ...
- UltraSoft - Beta - Scrum Meeting 4
Date: May 20th, 2020. Scrum 情况汇报 进度情况 组员 负责 今日进度 q2l PM.后端 完成了课程中心对课程提醒的爬虫 Liuzh 前端 修改DDL列表中起始时间为课程名 ...
- Machine learning (6-Logistic Regression)
1.Classification However, 2.Hypothesis Representation Python code: import numpy as np def sigmoid(z) ...