Python

字典

key不存在,报错场景

复制代码

dic={} dic['a'] # 报错 dic.get('a') # 不报错 返回None dic['a']=1 # 不报错,直接创建a=1的键值对 print(dic)

查看源码

cmd+click,蓝色面板里面显示了python内置是怎么实现字典的get,但是没有底层源码

方法入参

TypeVar来自typing.TypeVar,用于泛型占位。

复制代码

KT = TypeVar("KT") # 入参是name VT = TypeVar("VT")

用法举例

复制代码

from typing import TypeVar T = TypeVar('T') def demo(x: T) -> T: return x

  • "/"

    入参按照顺序传入get(k1) ✅,不允许写成k1=v1传入 get(k1=v1)❌

python的内置函数源码注册在CPython中

CPython源码:https://github.com/python/cpython/blob/main/Objects/dictobject.c#L3703

CPython是Python的解释器,由C语言实现。Python内置的函数,例如dict.get(k)的源码注册在CPython中,所以总说Python的底层是C语言。

调用顺序

.py - CPython 编译成中间码 - CPython 解释器 执行+调用c层函数

类比java : .java - jvm编译成.class中间码 - jvm解释器执行

复制代码

_PyDict_Subscript(PyObject *self, PyObject *key) { Py_hash_t hash = _PyObject_HashFast(key); if (hash == -1) { dict_unhashable_type(self, key); return NULL; } return _PyDict_SubscriptKnownHash(self, key, hash); }

Argument clinic机制

c层开发者利用Argument clinic工具,实现简单声明-> 代码生成。

复制代码

/*[clinic input] demo.add x: int y: int = 1 / Return x + y. [clinic start generated code]*/

Hashable

字典的key必须是hashable的。作为key的变量,在其生命周期,不会变。比如str,int等,但是数组1,2不行,作为key的话,内容发生变化,hash会发生变化,导致无法快速查找,视为unhashable。

相关推荐
biter down30 分钟前
基于 Pywinauto 的 QQ 音乐 GUI 自动化测试实践
python
人道领域32 分钟前
【LeetCode刷题日记】669.修剪二叉搜索树
开发语言·python·算法
EntyIU2 小时前
mineru从安装部署到测试使用完整指南
python·ocr
安替-AnTi2 小时前
厚朴 APK 搜索接口分析
python·apk·解析·taobao
山川湖海3 小时前
AI时代快速学编程语言的陷阱(以Python为例)
大数据·人工智能·python
H Journey3 小时前
Supervisor 进程管理工具介绍
python·supervisor·linux 运维
春日见3 小时前
5分钟入门强化学习之动态规划算法与实现
大数据·人工智能·python·算法·机器学习·计算机视觉
DeniuHe4 小时前
sklearn 中所有交叉验证数据集划分方式完整总结
人工智能·python·sklearn
DeniuHe4 小时前
sklearn中不同交叉验证方法的场景适配
人工智能·python·sklearn
隐于花海,等待花开5 小时前
16.Python 常用第三方库概览 深度解析
python