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

如何為使用Python語言而辯論

開發 后端
這篇文章的用意是幫助表明Python仍然對大多數軟件項目是切實可行的。我不擔心把Python推銷給反對其他動態語言(如Ruby)的人,因為我認為這些爭論與個人喜好有關。這篇文章是講給那些推銷靜態類型語言的人。

[[205208]]

最近我寫了一篇關于我為什么不擔心Python流失用戶的文章。幾分鐘之后有人問我Python的用法(usage),而這篇文章沒有提及,但卻是一個讓人深思的問題。我們看到,使用Python的用戶很可能在未來保持高位,但是Python是否會被用到盡可能多的項目中是不能保證的;用戶(users)數目很多而且穩定,但是項目中Python的用處(use)并不確定。

這篇文章的用意是幫助表明Python仍然對大多數軟件項目是切實可行的。我不擔心把Python推銷給反對其他動態語言(如Ruby)的人,因為我認為這些爭論與個人喜好有關。這篇文章是講給那些推銷靜態類型語言的人。具體上,這篇文章是針對Go的,但也可以是其他任何靜態類型語言。

“為什么Go?”,你可能會問。因為Go實際上在獲取Python的用戶。當2003到2005年間Python的增長曲線是個曲棍球棒時,Python還不是被推下山巔的王者,而是個弱者。傳統上,Python從Java之類的語言陣營中獲得用戶,并且留住了他們(我不想談C++用戶,因為通常他們有嚴格的性能需求,需要一個系統語言,或者是性能成癮者,并且需要好好恢復)。但是Go的情況不太一樣。如今Python是使用最多的語言之一,而不再是弱者了。一旦在靜態類型語言社區中出現一門語言,它的生產效率/性能的取舍相當好,那便足以說服一些Python的程序員選擇Go而不再是Python了。

如今的Go

首先我應該說,Go是目前我第二喜歡的語言。如果今天我要啟動一個項目,但不能說服人們使用Python,那我會提議使用Go。不要誤解我在本文中說Go是門不好的語言。這篇文章的要點是說服其他人,Python是生產率/性能取舍游戲中Go之外切實可行的替代方案,而不是表達Go是門不好的語言。認為這篇文章是反Go的,那就是你的個人想法,而且不應該這樣認為。

我應該說,我偶爾在工作中使用Go,并有點想關注這門語言的社區。既然我不能僅憑想象就成為Go專家,但這番話并不是僅從文檔或者博客中提取出來的。但是由于我是Python開發團隊的一份子,無論我如何試圖表現得公平,固有的偏見某種程度上還是有的。

那么,帶著這些警告,我們來看下Go提供給開發者什么。

生產率

我看待Go的方式是,使用你最喜歡的編程語言,移除那些難于加速生產率的特性,就是Go。靜態類型的影響被降到最小,因為通常只有在API邊界時你才會面對它。結構類型同樣使事情變得簡單(把它認為是鴨子類型)。語法并不笨拙(雖然它使用了花括號)。不要認為Go是C/C++去掉不安全的特性,加上生產率更高的東西,不然你會很失望(比如,“為什么我不能使用make()內置函數,也不能像map類型一樣對返回值進行計數”,這種看待Go的方式是錯誤的;這就是為什么C++開發者沒有轉到Go的原因)。快速編譯也使開發周期更像一個動態語言,而不是一個需要編譯的語言。而且事實上有些人喜歡沒有異常機制帶來的冗長,因為這促使你處理每種異常情形而不是(意外地)忽略它們(這是貫穿Go初始系統語言設計的實例)。還有,這門語言本身相當短小易記,并有嚴格的前向兼容性要求(forward-compatibility requirements)(你不可能更快地獲得泛型),大體上使用Go來編碼是件很愉快的事情。

由于是靜態類型,Go可以很容易地獲得工具支持(它對之前以此為設計目標的語言也有幫助)。Go確保核心工具跟隨Go本身提供,也是明智之舉。go fmt強制執行Go風格的規則,并允許通過用戶自定義的規則來重構代碼(“采用制表符縮進”不再是問題,因為這意味著你可以隨心所欲地設置編輯器來代表制表符,然后go fmt將其轉換為普通制表符以適用VCS)。go fix會更新代碼以跟***發布的版本保持一致。go get獲取依賴并安裝。

Go***一個生產率功能是它靜態編譯所有東西,使部署更簡單。如果你使用容器來開發和部署,這也不算什么。只有當你發布單個文件的命令行工具,而不是一組依賴和你自己的代碼時,這才算得上事。

性能

就性能來說,Go做的很好。很難指出任何基準能準確的證明Go總是最快的選擇,甚至計算機語言基準游戲中一些基準證明CPython 3是最快的。但是通常情況下可以認為對于你的任何工作來說Go已經足夠快了。

Go真正出色的地方是并發性(concurrency) 。要注意并發代碼并不是通常誤解的并行(parallelized)代碼; 并發代碼仍然可以是單線程的,僅僅在任務切換方面更加簡單/出色。Go通過使用goroutine使連續并發的代碼執行起來絕對的簡單。如果你不想使用共享內存的方式(雖然也同樣支持),該語言提供的通信管道允許以非常簡潔的消息傳遞方式進行并發編程。將所有特征整合進此語言中成為盡可能使用該語言開發并發代碼的又一原因。換句話說,Go程序運行很快,該語言盡力使你在合理的方式上獲得該效果。

如今的Python

如果順利的話我已經讓你相信Go是一種優秀的編程語言,除非因為其他原因,一些人不會認為我在整篇文章對Go的描述很糟糕。現在我們討論一下Python的生產率/性能是怎么樣的。

生產率

首先也是最重要的,Python非常容易學習。這也是為什么在當前高評價的美國大學中將Python作為***的教學語言 。這相當于該語言擁有成熟穩定的新程序員的來源以及更容易培訓其他程序員。 我想,要說服別人只用幾行Python代碼就會完成很多工作這并不難(Go/Python 3比較 顯示Python每次都比Go使用更少的代碼完成相同的工作)。所以我會堅持認為使用Python會更高產,即使和Go相比,這不會有人反對。

通常大家反對Python的地方是在工具支持方面。但是如果你注意到我指出的Go相關的支持工具,fmt, fix, 和 get, Python社區也有對等的工具。對遵循PEP 8的風格格式化(style formating), 可以在提交檢查時使用pep8,或者如果想要更多go fmt風格的自動重寫可以使用autopep8。對用于重構的go fix或go fmt,你可以說2to3也可以完成同樣的功能。對于go get, Python有pip。我們有venv/virtualenv或cx_Freeze這樣的代碼凍結工具(跟其他一樣,位于容器之上?on top of containerization like anything else),而不是靜態編譯的二進制包。甚至有貫穿項目的代碼分析工具如pylint。說Python因為缺少工具支持而不能用于大型項目,這種觀點對我來說是很膚淺的。

如果說有哪方面Python完全做的好,那就一定是它豐富的第三方擴展庫和相應的工具可供使用,就像在PyPI上面看到的那樣(我相信肯定有人忍不住要爭論說,“并不是所有的第三方庫都能夠在Python3上面運行啊”,事實確實如此,然而,這些第三方擴展庫對Python3的支持已經相當好了,而且還在繼續改善中,所以我不會太在意這個爭論,另外,你可以同時使用Python2/3兩個版本進行編碼,不需要關心針對哪個版本)。看一下godoc.org,上面顯示Go也并不缺少社區支持,Pytho之所以能夠擁有更多可用的第三方庫僅僅是因為它的年齡,這個狀態也會繼續持續。

性能

因為Python已經存在很久,且變得如此龐大, 簡單地去說 “Python是足夠快的” 不能說明整個的情況, 那是因為有各種各樣的實現加速的方式。但是在深入到VM級別的選項之后,意味著Python的stdlib提供了獲得加速的選項。舉例來說, concurrent.futures 是尷尬地執行并行代碼的方式,這種方式是極其簡單的。而在Python 3.3中,新的asyncio編寫了異步代碼。它沒有像Go那樣被集成進語言,在Python中的并發程序設計是可行的,且在方式上也未必是那么痛苦的。

但是***的辦法是,你可以在選擇的VM里改變Python代碼的性能。 

責任編輯:龐桂玉 來源: 36大數據
相關推薦

2015-09-16 17:30:20

安裝Go語言Linux

2010-02-22 09:17:39

使用Python

2022-10-17 09:08:01

2020-04-24 06:26:09

LinuxPython應用

2020-04-15 10:50:19

編程語言工具技術

2009-11-16 08:58:43

PHP語言

2010-03-12 13:44:31

Python whil

2015-10-15 11:27:02

cookie安全總結

2020-08-20 08:17:08

機器學習技術工具

2024-02-20 20:12:09

C語言字符串Redis

2022-07-29 15:08:05

加密貨幣去中心化工具

2021-10-29 15:40:33

SASE

2023-05-15 20:11:34

2013-06-09 16:49:56

布線系統TIA40Gb

2020-10-20 09:27:48

Python開發數據類型

2010-07-08 11:02:49

VMware Viewhypervisor

2010-07-08 10:56:53

VMware Viewhypervisor

2020-11-12 18:57:14

摘要PythonNLP

2011-09-13 10:13:45

JavaScript
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 欧美黄色小视频 | 男女羞羞视频网站 | 丁香色婷婷 | 欧美在线一区二区三区 | 国产精品久久久久久久久久久久 | 日韩在线观看网站 | 国产一区二区三区久久 | 国产精品欧美一区二区三区不卡 | 亚洲欧美日韩一区二区 | 亚洲女人天堂成人av在线 | 亚洲视频在线看 | 久草网站| av免费在线观看网站 | 亚洲精品一区二区 | 欧美日韩久久久 | 伊人焦久影院 | 天天在线操 | 亚洲一区二区视频 | 欧美成人一区二区三区 | 亚洲一区二区三区四区在线观看 | 黄色网页在线 | 久久久久久国模大尺度人体 | 一级一级一级毛片 | 一级黄色片美国 | 午夜av电影 | 久久久久久国产精品免费免费 | 日韩在线播放一区 | 成人av一区二区在线观看 | 午夜在线影院 | 99re在线视频免费观看 | 三区四区在线观看 | xx视频在线观看 | 精品一区二区三区在线观看国产 | 欧州一区二区三区 | 在线精品国产 | 国产精品中文字幕在线观看 | 一级特黄网站 | 美女在线一区二区 | 亚洲一区二区精品 | 殴美成人在线视频 | 99精彩视频 |