日本综合一区二区|亚洲中文天堂综合|日韩欧美自拍一区|男女精品天堂一区|欧美自拍第6页亚洲成人精品一区|亚洲黄色天堂一区二区成人|超碰91偷拍第一页|日韩av夜夜嗨中文字幕|久久蜜综合视频官网|精美人妻一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
到底該不該使用Python?

作者 | JOS VISSER

寶豐網(wǎng)站建設(shè)公司創(chuàng)新互聯(lián),寶豐網(wǎng)站設(shè)計制作,有大型網(wǎng)站制作公司豐富經(jīng)驗。已為寶豐上千余家提供企業(yè)網(wǎng)站建設(shè)服務(wù)。企業(yè)網(wǎng)站搭建\外貿(mào)網(wǎng)站制作要多少錢,請找那個售后服務(wù)好的寶豐做網(wǎng)站的公司定做!

編譯 | 王瑞平

最近,大家總在吐槽Python:“雖然它是一種不錯的語言,但不適用于專業(yè)領(lǐng)域?!?/p>

前不久,我在LinkedIn上找到一篇帖子,主要建議初級開發(fā)人員應(yīng)該學(xué)習(xí)哪種語言,以便獲得更好的工作機會,Python憑借出色的表現(xiàn)穩(wěn)居第一。

圖片

 其它證據(jù)同樣表明:Python確實太受歡迎了!近日,TIOBE編程社區(qū)公布了“2023年8月編程語言排行榜”。

數(shù)據(jù)顯示:Python依然排名第一,占比13.33%;C語言緊隨其后,排行第二,占比11.41%;C++位列第三,占比10.63%,與C語言差距為0.78%。

圖片

此外,Java和C#分別排在第四和第五位,占比分別為10.33%和7.04%。JavaScript在本月依然保持榜單第六位,占比為3.29%。

雖然Python如此受歡迎,但它能否持續(xù)流行依舊是一個重大問題,很多用戶普遍認(rèn)為,如果持續(xù)使用將會使行業(yè)倒退好幾年。

1、局限:Python無法開發(fā)大型應(yīng)用程序

Python對于開發(fā)大型應(yīng)用程序不太友好,在工程化實踐中需要特殊的技術(shù)支持。

“我曾用Python編寫過大型應(yīng)用程序很多年。由于Python入門非常簡單,在編寫大型應(yīng)用程序時就像用樂高積木構(gòu)建核反應(yīng)堆一樣?!痹髡咴谖恼轮行蜗蟮乇扔鞯?。

“但是,現(xiàn)在‘反應(yīng)堆’已經(jīng)運行很久,輻射泄漏到處都有,我們需要到處‘貼新磚’讓‘反應(yīng)堆’持續(xù)運轉(zhuǎn)?!?/p>

實際上,目前唯一能做的就是將“反應(yīng)堆”封裝在混凝土中讓它冷卻下來,然后再用合適的建筑材料構(gòu)建出一個新的。

認(rèn)為“Python無法開發(fā)大型應(yīng)用程序”的網(wǎng)友認(rèn)為它“不太友好”,在工程化實踐中需要特殊技術(shù)支持。

圖片

也有反對者認(rèn)為:在大型項目中,與影響更大的其它因素相比,編程語言的語法、語義、范式等幾乎無關(guān)緊要。團隊經(jīng)驗和熟悉度、開發(fā)管理、流程、實踐、支持工具、文檔、語言生態(tài)系統(tǒng)、語言成熟度、管理支持等都會對項目結(jié)果產(chǎn)生更大的影響。

另外,從技術(shù)層面來講,質(zhì)疑Python無法開發(fā)大型編程語言只能反映提問者對相關(guān)開發(fā)缺乏了解。這些質(zhì)疑一是源于Python的動態(tài)類型特性,使類型推斷變得困難,對代碼的靜態(tài)檢查和重構(gòu)十分不利;二是由于Python代碼沒有編譯過程,因此缺少編譯時檢查錯誤機制。

關(guān)于動態(tài)類型特性質(zhì)疑,Python從3.3版本起就引入類型聲明,因此,只要遵循規(guī)范編寫代碼,類型推斷和代碼重構(gòu)就不是問題。

不久前,ChatGPT的問世也證明了Python可以寫出高性能、可擴展性強的大型分布式計算平臺—Ray。目前,這個平臺已匯聚超過1億的月活躍用戶。

“糟糕的應(yīng)用程序架構(gòu)是絕大多數(shù)應(yīng)用產(chǎn)生性能瓶頸的原因,而不應(yīng)該由開發(fā)語言來背黑鍋。”有些評論者這樣認(rèn)為。

2、速度慢

誠然,Python與其它開發(fā)語言相比,在運行速度方面確實落后不少。究其根源,還是由于Python之父認(rèn)為不需要過多關(guān)注Python的速度問題,認(rèn)為它已經(jīng)足夠快了。

確實,對于99%以上的任務(wù)來說,Python的速度夠快,快到足以支撐早期Google和Dropbox。

自那時起,Python的速度又有了顯著提升,但開發(fā)者仍要求Python運行得更快。因為,無論人們已經(jīng)使用Python構(gòu)建出算力多么驚人的計算平臺,它的計算能力在很多場景下依然更慢。

3、功能差

當(dāng)然,Python是一種靈活的和duck類型的語言:我們鍵入代碼、保存它,然后僅在運行時才能根據(jù)輸入的數(shù)據(jù)確定語句始終有效、有時有效還是根本不可能實現(xiàn)。

此外,你在用Python編寫程序時,只能部分控制進(jìn)入該函數(shù)的數(shù)據(jù),需要嚴(yán)格檢查所有輸入的數(shù)據(jù)。

更糟糕的是,Python的duck式輸入方式可能會引入“可怕”代碼,這會帶來麻煩。

4、錯誤百出

我在用Python編寫大型應(yīng)用程序的這些年里,經(jīng)歷過一些可怕的事情;如果這些應(yīng)用程序是用理性的、安全的語言編寫的,這些事就不會發(fā)生。

*在幾年前的一個例子中,我設(shè)法說服組織用Rust重寫系統(tǒng),效果非常不錯!

實際上,我曾多次在社區(qū)中發(fā)布用Python編寫的大型應(yīng)用程序新版本,結(jié)果卻立即被錯誤“吞噬”;這些錯誤都是由Python代碼異常導(dǎo)致的。

*Python的捍衛(wèi)者會說,這不是語言的缺陷,而是代碼審查和測試方法的缺陷。

*他們錯了!理論上,測試方法主要是查看每一行代碼并檢查每個輸入和場景,但實際上這并不可能!

好的編程語言的特點之一是:你不必檢查和測試內(nèi)存中每個相關(guān)位置的排列;如果必須詳盡地檢查和測試每個“a=b+c”,程序?qū)⒖赡苡肋h(yuǎn)無法應(yīng)用于實踐。

我會經(jīng)常查看Python函數(shù),并想了解是否有人實際調(diào)用了它們以及攜帶了哪些參數(shù)。

我也經(jīng)常不得不“求助”代碼庫的全文搜索功能尋找調(diào)用位置;不幸的是,即便沒有輸出任何結(jié)果,當(dāng)我刪除相應(yīng)函數(shù)時,程序依然會崩潰;就算程序沒有立即崩潰,也無法判斷程序是否會在某種情況下崩潰。

5、分叉進(jìn)程,耗盡內(nèi)存

用Python的另一個問題是內(nèi)存。我的筆記本電腦有10個CPU內(nèi)核,其中,Python應(yīng)用程序大約占用1.2個。

這該怎么辦呢?幸運的是,我可以在Python中使用分叉工作進(jìn)程的功能處理請求,確保所有核心都能正常使用。

不幸的是,分叉進(jìn)程的操作很快就耗盡了內(nèi)存,所以我決定在處理完一定數(shù)量的請求后自行終止分叉,然后由Linux進(jìn)行內(nèi)存管理。雖然這并不是Python本身的問題,但Python使內(nèi)存管理變得更加糟糕。

分叉工作進(jìn)程還有另一個影響:Python使用引用計數(shù)法擊敗了寫時復(fù)制。為控制引用計數(shù),保存只讀變量的內(nèi)存塊也被寫入,從而耗費了一定的內(nèi)存。

解決這個問題的有效方法是:讓編譯器對所有由主進(jìn)程創(chuàng)建和由worker進(jìn)程繼承的變量使用參考數(shù)值,而不必觸及到具有該參考數(shù)值的引用計數(shù)。

這是超級聰明的解決方案,但我認(rèn)為應(yīng)該沒這個必要。如果你需要破解編譯器才能讓Python為你所用,那這種語言又有什么用呢?

總之,Python使編寫可靠、易于維護(hù)和快速的代碼變得非常困難。

6、將Python替換成GO

當(dāng)我對Python忍無可忍之時就會轉(zhuǎn)向Go,它使用起來幾乎與Python同樣容易、安全,還能快速構(gòu)建系統(tǒng)并生成高度優(yōu)化的二進(jìn)制本機代碼文件。

雖然Go也并不是完美的,但是,如果你想可靠和快速地編寫代碼,并在代碼失控時可以調(diào)試和重構(gòu),Go比Python好很多!

參考資料:

https://www.zhihu.com/question/321166662/answer/2937406779?utm_id=0

https://www.zhihu.com/question/321166662/answer/2937406779


本文名稱:到底該不該使用Python?
標(biāo)題鏈接:http://www.dlmjj.cn/article/djgccic.html