成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

為什么說 Python 內置函數并不是萬能的?

開發(fā) 后端
在Python貓的上一篇文章中,我們對比了兩種創(chuàng)建列表的方法,即字面量用法 [] 與內置類型用法 list(),進而分析出它們在運行速度上的差異。

 在Python貓的上一篇文章中,我們對比了兩種創(chuàng)建列表的方法,即字面量用法 [] 與內置類型用法 list(),進而分析出它們在運行速度上的差異。

[[346903]]

在分析為什么 list() 會更慢的時候,文中說到它需要經過名稱查找與函數調用兩個步驟,那么,這就引出了一個新的問題:list() 不是內置類型么,為什么它不能直接就調用創(chuàng)建列表的邏輯呢?也就是說,為什么解釋器必須經過名稱查找,才能“認識”到該做什么呢?

其實原因很簡單:內置函數/內置類型的名稱并不是關鍵字,它們只是解釋器內置的一種便捷功能,方便開發(fā)者開箱即用而已。

PS:內置函數 built-in function 和內置類型 built-in type 很相似,但 list() 實際是一種內置類型而不是內置函數。我曾對這兩種易混淆的概念做過辨析,請查看這篇文章。為了方便理解與表述,以下統(tǒng)稱為內置函數。

1、內置函數的查找優(yōu)先級最低

內置函數的名稱并不屬于關鍵字,它們是可以被重新賦值的。

比如下面這個例子:

 

  1. # 正常調用內置函數 
  2. list(range(3))  # 結果:[0, 1, 2] 
  3.  
  4. # 定義任意函數,然后賦值給 list 
  5. def test(n): 
  6.     print("Hello World!"
  7. list = test 
  8. list(range(3)) # 結果:Hello World! 

 

 

 

在這個例子中,我們將自定義的 test 賦值給了 list,程序并沒有報錯。這個例子甚至還可以改成直接定義新的同名函數,即"def list(): …"。

這說明了 list 并不是 Python 限定的關鍵字/保留字。

查看官方文檔,可以發(fā)現(xiàn) Python3.9 有35個關鍵字,明細如下:

 

 

 

 

如果我們將上例的 test 賦值給任意一個關鍵字,例如"pass=test",就會報錯:SyntaxError: invalid syntax。

由此,我們可以從這個角度看出內置函數并不是萬能的:它們的名稱并不像關鍵字那般穩(wěn)固不變,雖然它們處在系統(tǒng)內置作用域里,但是卻可以被用戶局部作用域的對象所輕松攔截掉!

因為解釋器查找名稱的順序是“局部作用域->全局作用域->內置作用域”,因此內置函數其實是處在最低優(yōu)先級。

對于新手來說,這有一定的可能會發(fā)生意想不到的情況(內置函數有 69 個,要全記住是有難度的)。

那么,為什么 Python 不把所有內置函數的名稱都設為不可復寫的關鍵字呢?

一方面原因是它想控制關鍵字的數量,另一方面可能是想留給用戶更多的自由。內置函數只是解釋器的推薦實現(xiàn)而已,開發(fā)者可以根據需要,實現(xiàn)出與內置函數同名的函數。

不過,這樣的場景極少,而且開發(fā)者一般會定義成不同名的函數,以 Python 標準庫為例,ast模塊有 literal_eval() 函數(對標 eval() 內置函數)、pprint 模塊有 pprint() 函數(對標 print() 內置函數)、以及itertools模塊有 zip_longest() 函數(對標 zip() 內置函數)……

2、內置函數可能不是最快的

由于內置函數的名稱并非保留的關鍵字,以及它處于名稱查找的末位順序,所以內置函數有可能不是最快的。

 

 

 

 

上篇文章展示了 [] 比 list() 快 2~3 倍的事實,其實這還可以推廣到 str()、tuple()、set()、dict() 等等內置類型中,都是字面量用法稍稍快于內置類型用法。

對于這些內置類型,當我們調用 xxx() 時,可以簡單理解成正在做類的實例化。在面向對象語言中,類先實例化再使用,這是再正常不過的。

但是,這樣的做法有時也顯得繁瑣。為了方便使用,Python 給一些常用的內置類型提供了字面量表示法,也就是""、[]、()、{} 等等,表示字符串、列表、元組和字典等數據類型。

 

 

文檔出處:https://docs.python.org/3/reference/lexical_analysis.html#delimiters

 

 

一般而言,所有編程語言都必須有一些字面量表示,但基本都局限在數字類型、字符串、布爾類型以及 null 之類的基礎類型。

Python 中還增加了幾種數據結構類型的字面量,所以是更為方便的,同時這也解釋了為什么內置函數可能不是最快的。

一般而言,同樣的完備功能,內置函數總是比我們自定義的函數要快,因為解釋器可以做一些底層的優(yōu)化,例如 len() 內置函數肯定比用戶定義的 x.len() 函數快。

有些人據此形成了“內置函數總是更快”的認識誤區(qū)。

解釋器內置函數相對于用戶定義函數,前者接近于走后門;而字面量表示法相對于內置函數,前者是在走更快的后門。

也就是說,在有字面量表示法的情況下,某些內置函數/內置類型并不是最快的!

小結

誠然,Python 本身并不是萬能的,那它的任何語法構成部分(內置函數/類型),就更不是萬能的了。但是,一般我們會認為內置函數/類型總歸是“高人一等”的,是受到諸多特殊優(yōu)待的,顯得像是“萬能的”。

本文從“list() 竟然會敗給 []”破題,從兩個角度揭示了內置函數其實存在著某種不足:內置函數的名稱并不是關鍵字,而內置作用域位于名稱查找的最低優(yōu)先級,因此在調用時,某些內置函數/類型的執(zhí)行速度就明顯慢于它們對應的字面量表示法。

本文對上一個“Python為什么”話題做了延展討論,一方面充實了前面的內容,另一方面,也有助于大家理解 Python 的幾個基礎概念及其實現(xiàn)。

責任編輯:華軒 來源: Python貓
相關推薦

2021-06-11 09:23:30

微服務架構分層架構

2015-08-26 13:49:28

數據中心

2020-10-31 21:47:06

Python數據結構開發(fā)

2022-03-13 23:19:04

元宇宙區(qū)塊鏈數字貨幣

2022-06-27 08:36:08

PythonLambda

2014-02-17 10:56:21

Hadoop

2022-11-30 13:13:41

節(jié)能減碳PUE

2020-11-04 10:23:21

云計算數字化轉型IT基礎設施

2017-12-15 14:00:11

物聯(lián)網互聯(lián)網IoT

2011-07-26 13:47:06

AndroidLinux

2017-10-18 22:18:09

2015-12-17 11:04:00

云開支云計算

2015-05-08 07:29:42

OpenStack云方案云服務成本

2021-07-15 06:43:12

SQLSelect命令

2021-11-11 10:41:25

代碼開發(fā)工具

2015-09-15 10:54:54

HTTP2 WEB 性能優(yōu)化

2011-07-28 09:45:59

云計算

2011-08-31 15:52:26

微軟

2021-06-24 08:20:15

MySQL數據庫索引

2009-04-28 09:13:27

MySQLOracle收購
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 亚洲精品久久久久久一区二区 | 欧美日韩在线视频一区二区 | 欧美aⅴ片| 一区二区免费 | 亚洲精品一区二区三区在线 | 日韩精品一区二区三区中文在线 | 北条麻妃国产九九九精品小说 | 特一级黄色毛片 | 午夜精品一区二区三区在线观看 | 伊人久麻豆社区 | 日韩网站在线 | 久久久www成人免费精品 | 日韩在线国产 | 欧美精品v国产精品v日韩精品 | 成人免费精品 | 在线观看的av | 欧美精品日韩精品国产精品 | 一区二区小视频 | 美女黄视频网站 | 欧美日韩国产高清 | 亚洲高清av在线 | 亚洲国产精品一区在线观看 | 日本不卡在线观看 | 日韩精品视频一区二区三区 | 婷婷久久精品一区二区 | 久久激情网 | 狠狠综合久久av一区二区小说 | 国产综合久久 | 国产麻豆一区二区三区 | 2019天天操 | 亚洲精品观看 | 九九视频网| 欧美精品一区二区三区在线四季 | 久久欧美高清二区三区 | 国产免费观看一级国产 | 日韩三片 | 日韩国产一区二区三区 | 国产视频1区2区 | 91精品久久久久久久 | 天堂一区二区三区 | 中文字幕日韩欧美 |