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

Python編程語言的核心是什么?

開發 后端
我們需要一個用于WebAssembly的Python實現,這已經不是什么秘密了。它不僅將Python引入到瀏覽器中,而且由于iOS和Android都支持將JavaScript作為應用的一部分運行,它也將Python引入到移動端。這一切都讓我興奮。

 為什么問這個問題?

我們需要一個用于WebAssembly的Python實現,這已經不是什么秘密了。它不僅將Python引入到瀏覽器中,而且由于iOS和Android都支持將JavaScript作為應用的一部分運行,它也將Python引入到移動端。這一切都讓我興奮。

但是,當想到創建一個新的Python實現這一令人生畏的任務時,我的大腦也開始問這個問題:Python到底是什么?我們與CPython一起生活了這么長時間,我懷疑我們中的大多數人只是簡單地認為“Python == CPython”。PyPy試圖做到兼容,以便實現CPython的實現細節。基本上,我所知道的大多數Python實現都努力通過CPython的測試套件,并盡可能地與CPython兼容。

這是令人生畏的。由CPython實現的Python是非常動態的,并且暴露了許多只有在使用解釋器實現Python時才有意義的東西。例如,PyPy有一個用于JIT的基線解釋器,但是在Python中可以使用許多東西來強制PyPy關閉JIT并堅持使用字節碼。僅靠REPL就可以使事情變得非常動態,因為解釋器會立即對進入REPL的所有內容進行動態解析、編譯和執行。

這讓我開始思考Python到底是什么?這門語言的核心是什么?所有的Python實現需要涵蓋什么樣的基線,才能真正能夠將自己稱為人們仍能認出的Python實現?或者從我的角度來看,一個人需要實現多少才能直接編譯Python到WebAssembly,并且仍然被認為是Python實現?

 

[[335938]]

 

Python需要REPL嗎?

真正讓我開始思考這個問題的是當我開始思考如何將Python編譯成WebAssembly?沒有實現另一個解釋器,但實際上發出靜態WebAssembly從Python源代碼,并仍然合理地稱為“Python”。

我知道的一件事是,通過eval()或compile()進行動態編譯可能不太容易,因為WebAssembly的安全模型在加載時驗證模塊。這就意味著在其他代碼的內存空間中并不存在運行任意代碼的結構,這可能會使REPL的實現變得棘手。

但這讓我思考:Python真的需要REPL嗎?不要誤解我的意思,它非常方便,但是如果一個實現沒有REPL,它就不再是Python了嗎?我認為沒有應答的Python仍然是Python,它只是缺少一個(潛在的關鍵)特性。

這讓我開始思考Python的哪些部分需要被認為是“Python”?

沒有當地人你能生活嗎?它是一個非常動態的事情,能夠任意地收集所有定義的局部變量和它們的值到一個字典。如果你在一個像CPython這樣的intepreter中,你只需要從當前執行框架中獲取一些局部變量。但是在編譯語言中,這需要做更多的工作,因為您必須知道何時收集所有這些信息,因為調用local()時,這些信息并不一定是到處都有的。

或者人們重寫local()本身怎么樣?在CPython中,這不是什么大問題,因為builtins模塊有一個__dict__,你可以覆蓋它,它將簡單地傳播到任何未來的調用。但是在編譯語言中,進行這種檢測需要花費更多的精力,而且這樣的檢查最終會降低性能。

關于sys.settrace ()呢 ?它實際上會觸發每個字節碼的回調,如果代碼被編譯,它就不能正常工作。您可以通過檢查是否在每一行后面設置了跟蹤函數來偽造它,但是當您大多數時候沒有設置這樣的鉤子時,這樣做似乎有點過分(不過,它可能是在這種支持下編譯的編譯器標志)。

那么sys._getframe()呢?編譯語言并不一定要直接訪問執行框架,所以您需要費心去模擬它嗎?由于執行幀可以被任何函數請求,所以您需要隨時準備按需提供執行幀。

正如您所看到的,Python中有很多東西使得編譯變得困難(Nuitka因此更有能力接受這個挑戰)。但我敢打賭,我上面提到的東西你在99.9%的時間里都不會用到,所以如果一個實現沒有使用它們,它還能被認為是“Python”嗎?

有多少兼容性是有用的?

我對這個問題沒有很好的答案。但是它的答案說明了實現Python的難度以及它與現有軟件的兼容性。我想說的是,我認為WebAssembly不需要支持大量的Python軟件就可以發揮作用。WebAssembly可以訪問其他語言生態系統,比如Rust和JavaScript,所以用其他語言實現需要的東西的可能性絕對大于零。

我沒有答案

開發一個將Python代碼直接轉換為WebAssembly并犧牲一些兼容性以提高性能的編譯器可能是有意義的。開發一個以WebAssembly的設計為目標,同時又能保持與現有代碼的兼容性的解釋器可能是有意義的。在他們的WebAssembly努力中,簡單地支持RustPython可能是有意義的。也許Pyodide能幫我們到達那里。我不認為這些可能性在本質上都是錯誤的,它可能只會歸結為引起人們足夠興趣的那一個,從而看到它對別人有用。

責任編輯:華軒 來源: 今日頭條
相關推薦

2021-11-09 23:15:20

編程語言本質

2012-05-16 13:11:28

編程語言開發語言Java

2022-08-17 17:57:37

GoGo語言

2022-08-26 09:51:49

索引簽名編程語言

2018-04-04 14:29:33

2020-03-10 11:00:22

CIO核心競爭力競爭力

2021-03-15 14:00:56

PythonC語言編程語言

2021-07-07 10:01:13

編程語言計算機斯坦福大學

2021-02-07 09:18:07

JavaScript 前端編程語言

2009-07-20 15:42:59

JDBC是什么

2025-03-24 00:25:00

Go語言并發編程

2010-03-19 09:39:17

Python編程語言

2015-08-26 09:54:19

物聯網

2022-09-21 13:53:15

C++移動語義

2017-02-05 14:49:39

2009-07-08 14:51:10

2014-07-02 09:56:33

2009-09-23 15:50:57

Python 3.1

2010-02-24 16:23:46

Python核心編程

2015-08-12 13:23:37

運營商
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: caoporn国产精品免费公开 | 国产激情91久久精品导航 | 自拍亚洲 | 男人天堂国产 | 亚洲欧美aⅴ | 国产午夜精品一区二区三区嫩草 | 岛国av一区二区 | 久久久毛片 | 亚洲成人免费视频在线 | 91视频在线 | 欧美xxxx色视频在线观看免费 | 亚洲影音 | 日产久久| 国产一区二区在线播放 | 亚洲免费精品一区 | 国产一区二区三区 | 综合二区 | 欧美精品一区二区三区在线播放 | 亚洲精品中文字幕在线观看 | 中文字幕av一区 | 日本一二三区高清 | 成人免费视频一区 | 91久久国产综合久久 | 亚洲精品永久免费 | 日韩三区| 国产精品久久欧美久久一区 | 综合国产| 国产精品区一区二 | 亚州精品天堂中文字幕 | 91色网站 | 欧美精品在线一区二区三区 | 天堂精品 | 国产精品日韩高清伦字幕搜索 | 久色网| 欧美在线观看一区 | av在线成人 | 国产精品久久久久久高潮 | 亚洲精品乱码8久久久久久日本 | 国产免费av在线 | 久久精品国产一区二区三区 | 国产午夜精品视频 |