Python 3.8新功能盤點:更快,更簡潔,更一致,更現(xiàn)代化
從功能強大的新任務(wù)語法到底層大更新,Python 3.8邁向更現(xiàn)代的Python代碼庫。
3.8是Python這個流行語言的***版本,適用于從自動化腳本編寫、機器學(xué)習(xí)到Web開發(fā)的所有內(nèi)容?,F(xiàn)在可以獲得官方測試版,Python 3.8帶來了許多靈活的語法更改,內(nèi)存共享,更高效的序列化和反序列化,修改后的詞典等等。
當然,Python 3.8也***了各種性能改進。總體結(jié)果是讓Python更快,更簡潔,更一致,更現(xiàn)代化。以下是Python 3.8中***,最重要的內(nèi)容。
賦值表達式
Python 3.8中最明顯的變化是賦值表達式,它使用了酷似海象的運算符(:=)。賦值表達式允許在表達式的上下文中將值賦給變量,甚至是尚不存在的變量,而不是作為獨立語句。
- while (line := file.readline()) != "end":
- print(chunk)
在此示例中,如果變量行不存在,則創(chuàng)建變量行,然后從file.readline()分配值。然后檢查行以查看它是否等于“結(jié)束”。如果不是,則讀取下一行,存儲在行中,測試,等等。
賦值表達式遵循Python中可理解的簡潔性的傳統(tǒng),包括列表推導(dǎo)。在這里,我們的想法是減少一些易于出現(xiàn)在某些Python編程模式中的繁瑣樣板。例如,上面的代碼片段通常需要多于兩行代碼才能表達。
強制某些參數(shù)僅為位置
函數(shù)定義的新語法,僅位置參數(shù),允許開發(fā)人員強制某些參數(shù)僅為位置。這消除了關(guān)于函數(shù)定義中哪些參數(shù)是位置的以及哪些是關(guān)鍵字參數(shù)的任何歧義。
僅限位置參數(shù)可以定義場景,例如,函數(shù)接受任何關(guān)鍵字參數(shù)但也可以接受一個或多個位置。 Python內(nèi)置函數(shù)通常就是這種情況,因此為Python開發(fā)人員提供了一種方法,可以增強語言的一致性。
Python文檔中的一個例子:
- def pow(x, y, z=None, /):
- r = x**y
- if z is not None:
- r %= z
- return r
/將位置與關(guān)鍵字參數(shù)分開; 在這個例子中,所有的參數(shù)都是位置的。在以前的Python版本中,z將被視為關(guān)鍵字參數(shù)。 給定上述函數(shù)定義,pow(2,10)和pow(2,10,5)是有效調(diào)用,但pow(2,10,z = 5)不是。
F字符串調(diào)試支持
f-string格式提供了一種方便(且性能更高)的方式來在同一表達式中打印文本和計算值或變量:
- x = 3
- print(f'{x+1}')
這將打印4。
在f字符串表達式的末尾添加=會打印f-string表達式本身的文本,后跟值:
- x = 3
- print (f'{x+1=}')
這將打印x + 1 = 4。
多處理模塊共享內(nèi)存
使用Python 3.8,多處理模塊現(xiàn)在提供了一個SharedMemory類,允許在不同的Python進程之間創(chuàng)建和共享內(nèi)存區(qū)域。
在以前的Python版本中,只能通過將數(shù)據(jù)寫入文件,通過網(wǎng)絡(luò)套接字發(fā)送或使用Python的pickle模塊對其進行序列化來在進程之間共享數(shù)據(jù)。共享內(nèi)存為在進程之間傳遞數(shù)據(jù)提供了更快的路徑,使Python能夠更有效地使用多個處理器和處理器內(nèi)核。
共享內(nèi)存段可以分配為字節(jié)的原始區(qū)域,或者它們可以使用不可變的類似列表的對象,這些對象存儲Python對象的一小部分 - 數(shù)字類型,字符串,字節(jié)對象和None對象。
打字模塊的改進
Python是動態(tài)類型的,但支持通過輸入模塊使用類型提示,以允許第三方工具驗證Python程序。 Python 3.8為鍵入添加了新元素,以便更加可靠地進行檢查:
- final decorator 和Final type annotation表明decorated/annotated 的對象不應(yīng)在任何位置被覆蓋,子類化或重新分配。
- Literal類型將表達式限制為特定值或值列表,不一定是相同類型。
- TypedDict類型允許創(chuàng)建字典,其中與某些鍵關(guān)聯(lián)的值僅限于一個或多個特定類型。 請注意,這些限制僅限于在編譯時可以確定的內(nèi)容,而不是在運行時。
新版本的pickle協(xié)議
Python的pickle模塊提供了一種序列化和反序列化Python數(shù)據(jù)結(jié)構(gòu)的方法,例如,允許將字典原樣保存到文件中并在以后重新加載。不同版本的Python支持不同級別的pickle協(xié)議,更新版本支持更廣泛的功能和更高效的序列化。
使用Python 3.8引入的pickle第5版提供了一種新方法,來pickle實現(xiàn)Python緩沖區(qū)協(xié)議的對象,例如字節(jié),內(nèi)存視圖或NumPy數(shù)組。新的pickle減少了必須為這些對象制作的內(nèi)存副本數(shù)量。
像NumPy和Apache Arrow這樣的外部庫在他們的Python綁定中支持新的pickle協(xié)議。新的pickle也可以作為PyPI的Python 3.6和Python 3.7的附件提供。
可逆詞典
Python中的字典完全用Python 3.6重寫,使用PyPy項目提供的新實現(xiàn)。除了更快更緊湊外,詞典現(xiàn)在還具有其元素的固有順序;它們是在添加時訂購的,就像列表一樣。 Python 3.8允許在字典上使用reversed()。
性能改進
- 許多內(nèi)置方法和函數(shù)已經(jīng)加速了20%到50%,因為其中許多方法和函數(shù)不必要地轉(zhuǎn)換傳遞給它們的參數(shù)。
- 新的操作碼緩存可以加速解釋器中的某些指令。但是,目前唯一實現(xiàn)的加速是針對LOAD_GLOBAL操作碼,現(xiàn)在快40%。計劃對更高版本的Python進行類似的優(yōu)化。
- 文件復(fù)制操作(例如shutil.copyfile()和shutil.copytree())現(xiàn)在使用特定于平臺的調(diào)用和其他優(yōu)化來加速操作。
- 由于優(yōu)化利用列表構(gòu)造函數(shù)對象的長度(如果事先已知),現(xiàn)在新創(chuàng)建的列表現(xiàn)在平均比以前小12%。
- 在Python 3.8中,在新式類(例如,類A(對象))上寫入類變量要快得多。
- operator.itemgetter()和collections.namedtuple()也有新的速度優(yōu)化。
Python C API和CPython改進
在Python的***版本中,主要的工作是重構(gòu)CPython中使用的C API,這是用C編寫的Python的參考實現(xiàn)。到目前為止,這項工作只產(chǎn)生了增量變化,但它們正在加起來:
- 用于Python初始化配置的新C API允許對Python的初始化例程進行更嚴格的控制和更詳細的反饋。 這樣可以更輕松地將Python運行時嵌入到應(yīng)用程序中,并以編程方式將啟動參數(shù)傳遞給Python。 這個新API還旨在確保所有Python的配置控件都具有單一,一致的主頁,以便將來更改(如Python的新UTF-8模式)更容易插入。
- 另一個用于CPython的新C API,即“vectorcall”調(diào)用協(xié)議,允許更快地調(diào)用內(nèi)部Python方法,而無需創(chuàng)建臨時對象來處理調(diào)用。API仍然不穩(wěn)定,但已暫時可用。 計劃是從Python 3.9開始最終確定它。
- Python運行時審計掛鉤在Python運行時中提供了兩個API,用于掛鉤事件并使它們可以觀察到外部工具,如測試框架或日志記錄和審計系統(tǒng)。



























