Python中的“特权种族”是什么?

简介: 今天,猫猫把学习到的部分内容总结出来,分享给大家。阅读本文,大家可以学到如下内容:1、对象的Id是什么?2、内置id()函数是什么?3、共用Id的内存分配策略?特权种族?

今天,猫猫把学习到的部分内容总结出来,分享给大家。阅读本文,大家可以学到如下内容:

1、对象的Id是什么?2、内置id()函数是什么?3、共用Id的内存分配策略?特权种族?

学习群里的一道问题

首先,看看小伙伴贴出的代码:

In [1]: a=[1,2,3]In [2]: id(a)Out[2]: 2399283020744In [3]: id(a.append(4))Out[3]: 1417427824In [4]: a.append(4)In [5]: id(a)Out[5]: 2399283020744复制代码

他的问题是:为何第二个id值(1417427824)不等于其它两个的id值(2399283020744)?还有这个id值(1417427824)到底是谁的id?

现在公布答案:第二个id值(1417427824)是None的id,只要打印id(None)就能看出来;至于为啥是None的id,因为列表的append()方法返回值是None,而id(a.append(4))等价于取这个append操作的返回值的id,也就是说id(a.append(4))等价于是id(None)。

对象Id与id()函数

python的对象有三要素:Id(identity,身份标识)、Type(类型标识)和Value(对象的值)。

其中,Value通常是一个对象能被直接“看到”的部分,而Id及Type则是相对底层的维度,无法直接“看到”。举个例子(“>>>”表示输出结果):

Object1=2018Object2="2018"# Object1的value是2018(数字)# Object2的value是“2018”(字符串)id(Object1) >>>2399282764784id(Object2) >>>2399281922600type(Object1) >>>inttype(Object2) >>>str复制代码

如上所述,我们建立了对象三要素与三个内置函数的联系:Id&id()、Type&type()、Value&str()。今天,猫猫先跟大家一起来学习id()函数,今后再继续学习其它两个。

1、id()函数释义

id()是python内置的函数,它专门用于获取对象的内存地址,内存地址是一个整型数值,在该对象的生命周期内是唯一且恒定的。语法:id([object])。

2、比较Id的两种方式

通常有两种比较对象Id的方式(is、id()比较),请看例子:

l1 = [1, 2, 3]l2 = [1, 2, 3]In [43]: l1 is l2 Out[43]: FalseIn [46]: id(l1)==id(l2)Out[46]: False# 两者Id不相等,因为:In [44]: id(l1)Out[44]: 2399279725576In [45]: id(l2)Out[45]: 2399282938056复制代码

is判断语句是判断两个对象的内存地址,也就等价于先取id(),再做数值比较。

3、不要与Value的比较方式混淆

Value的比较符号用双等号“==”,上例中比较l1和l2的Value要写成“l1 == l2”,明显两者的Value是相等的。按照约定俗成的习惯,我们把Value值相等的两个对象称为“相等”,而把Id值相等的两个对象称为“相同”。

所以,准确地说,上例的l1与l2相等,但是他们不相同,l1==l2,但l1 is not l2。

特权种族:共用内存的对象

每个对象被创建出来的时候,就会确定其Id标识,也就是给它分配内存地址。通常来说,新对象的内存地址也是新的,会从未分配的可用地址中取。

但是,为了提高内存利用效率,对于一些常用的对象,如一些数值较小的数字对象、布尔值对象、None对象、较短的字符串对象等等,python采取共用对象内存的分配策略。

# 新分配内存地址的例子ww=[1,2]ee=[1,2]id(ww)==id(ee) >>>Falsea=2018b=2018id(a)==id(b) >>>False# 共用内存地址的例子a=100b=100id(a)==id(b) >>>Truef1=Truef2=Trueid(f1)==id(f2) >>>Truen1=Nonen2=Noneid(n1)==id(n2) >>>Trues="python_cat"t="python_cat"id(s)==id(t) >>>True复制代码

这就意味着,python中出现了“特权种族”,运行环境早早就为它们分配好了内存地址,一旦要创建新的对象时,先去特权种族中查找,有Type和Value相等的对象,则新对象不分配新的内存空间,而是指向已有对象。

“特权种族”的存在,使得我们不需要频繁创建这些对象,既能提高已分配内存的使用率,又减少了创建对象、分配新内存的损耗。

对于共用内存地址的数字对象的取值范围,根据这篇文章《Python中神秘的-5到256》(链接见文末)对python源码的分析,文中有如下结论:

Python中,对于整数对象,如果其值处于[-5,256]的闭区间内,则值相同的对象是同一个对象。

对于共用内存地址的字符串对象的取值范围,学习了几篇对python源码分析的文章后(链接见文末),猫猫总结出大致有以下结论:

Python中,字符串使用Intern机制实现内存地址共用,长度不超过20,且仅包括下划线、数字、字母的字符串才会被intern;涉及字符串拼接时,编译期优化结果会与运行期计算结果不同。

# 编译对字符串拼接的影响s1 = "hell"s2 = "hello""hell" + "o" is s2 >>>Trues1 + "o" is s2 >>>False# "hell" + "o"在编译时变成了"hello",# 而s1+"o"因为s1是一个变量,在运行时才拼接,所以没有被intern复制代码

参考阅读:《Python中神秘的-5到256》(https://zhuanlan.zhihu.com/p/33907983)《Python中字符串的intern机制》(https://www.cnblogs.com/greatfish/p/6045088.html)《Python中字符串的intern机制》(https://mrcuriosity.org/python-string-intern.html


目录
相关文章
|
8月前
|
人工智能 API 开发工具
【Python+百度API】实现人脸识别和颜值检测系统(包括人脸数量、年龄、颜值评分、性别、种族、表情检测)(超详细 附源码)
【Python+百度API】实现人脸识别和颜值检测系统(包括人脸数量、年龄、颜值评分、性别、种族、表情检测)(超详细 附源码)
382 0
|
29天前
|
人工智能 数据可视化 数据挖掘
探索Python编程:从基础到高级
在这篇文章中,我们将一起深入探索Python编程的世界。无论你是初学者还是有经验的程序员,都可以从中获得新的知识和技能。我们将从Python的基础语法开始,然后逐步过渡到更复杂的主题,如面向对象编程、异常处理和模块使用。最后,我们将通过一些实际的代码示例,来展示如何应用这些知识解决实际问题。让我们一起开启Python编程的旅程吧!
|
27天前
|
存储 数据采集 人工智能
Python编程入门:从零基础到实战应用
本文是一篇面向初学者的Python编程教程,旨在帮助读者从零开始学习Python编程语言。文章首先介绍了Python的基本概念和特点,然后通过一个简单的例子展示了如何编写Python代码。接下来,文章详细介绍了Python的数据类型、变量、运算符、控制结构、函数等基本语法知识。最后,文章通过一个实战项目——制作一个简单的计算器程序,帮助读者巩固所学知识并提高编程技能。
|
16天前
|
Unix Linux 程序员
[oeasy]python053_学编程为什么从hello_world_开始
视频介绍了“Hello World”程序的由来及其在编程中的重要性。从贝尔实验室诞生的Unix系统和C语言说起,讲述了“Hello World”作为经典示例的起源和流传过程。文章还探讨了C语言对其他编程语言的影响,以及它在系统编程中的地位。最后总结了“Hello World”、print、小括号和双引号等编程概念的来源。
102 80
|
2月前
|
存储 索引 Python
Python编程数据结构的深入理解
深入理解 Python 中的数据结构是提高编程能力的重要途径。通过合理选择和使用数据结构,可以提高程序的效率和质量
150 59
|
5天前
|
Python
[oeasy]python055_python编程_容易出现的问题_函数名的重新赋值_print_int
本文介绍了Python编程中容易出现的问题,特别是函数名、类名和模块名的重新赋值。通过具体示例展示了将内建函数(如`print`、`int`、`max`)或模块名(如`os`)重新赋值为其他类型后,会导致原有功能失效。例如,将`print`赋值为整数后,无法再用其输出内容;将`int`赋值为整数后,无法再进行类型转换。重新赋值后,这些名称失去了原有的功能,可能导致程序错误。总结指出,已有的函数名、类名和模块名不适合覆盖赋新值,否则会失去原有功能。如果需要使用类似的变量名,建议采用其他命名方式以避免冲突。
27 14
|
14天前
|
分布式计算 大数据 数据处理
技术评测:MaxCompute MaxFrame——阿里云自研分布式计算框架的Python编程接口
随着大数据和人工智能技术的发展,数据处理的需求日益增长。阿里云推出的MaxCompute MaxFrame(简称“MaxFrame”)是一个专为Python开发者设计的分布式计算框架,它不仅支持Python编程接口,还能直接利用MaxCompute的云原生大数据计算资源和服务。本文将通过一系列最佳实践测评,探讨MaxFrame在分布式Pandas处理以及大语言模型数据处理场景中的表现,并分析其在实际工作中的应用潜力。
49 2
|
28天前
|
小程序 开发者 Python
探索Python编程:从基础到实战
本文将引导你走进Python编程的世界,从基础语法开始,逐步深入到实战项目。我们将一起探讨如何在编程中发挥创意,解决问题,并分享一些实用的技巧和心得。无论你是编程新手还是有一定经验的开发者,这篇文章都将为你提供有价值的参考。让我们一起开启Python编程的探索之旅吧!
46 10
|
1月前
|
机器学习/深度学习 人工智能 Java
Python 语言:强大、灵活与高效的编程之选
本文全面介绍了 Python 编程语言,涵盖其历史、特点、应用领域及核心概念。从 1989 年由 Guido van Rossum 创立至今,Python 凭借简洁的语法和强大的功能,成为数据科学、AI、Web 开发等领域的首选语言。文章还详细探讨了 Python 的语法基础、数据结构、面向对象编程等内容,旨在帮助读者深入了解并有效利用 Python 进行编程。
|
30天前
|
机器学习/深度学习 人工智能 数据挖掘
探索Python编程的奥秘
在数字世界的海洋中,Python如同一艘灵活的帆船,引领着无数探险者穿梭于数据的波涛之中。本文将带你领略Python编程的魅力,从基础语法到实际应用,一步步揭开Python的神秘面纱。
44 12