python編程 為什么Python效率這么低,還這么火?
為什么Python效率這么低,還這么火?在許多情況下,性能不是瓶頸。大約80%的應(yīng)用程序不需要高性能。Python語言其實(shí)很慢,為什么機(jī)器學(xué)習(xí)這種快速算法步驟通常還是用呢?對(duì)于那些使用了多種開發(fā)語言(
為什么Python效率這么低,還這么火?
在許多情況下,性能不是瓶頸。大約80%的應(yīng)用程序不需要高性能。
Python語言其實(shí)很慢,為什么機(jī)器學(xué)習(xí)這種快速算法步驟通常還是用呢?
對(duì)于那些使用了多種開發(fā)語言(Java、C#、nodejs、Erlang)然后轉(zhuǎn)用Python進(jìn)行機(jī)器學(xué)習(xí)的人,我想談?wù)勎业目捶ā?/p>
首先,Python真的很慢嗎?我的回答是真的。非常慢。for循環(huán)比CPP慢兩個(gè)數(shù)量級(jí)。
那么為什么要使用Python呢?如果我們遍歷超過一億個(gè)數(shù)據(jù),兩個(gè)數(shù)量級(jí)的差異是不可接受的。但是,如果我們使用Python來執(zhí)行頂層邏輯并阻塞數(shù)以億計(jì)的數(shù)據(jù),Python只會(huì)循環(huán)十幾次,剩下的就留給CPU和GPU了。所以兩個(gè)數(shù)量級(jí)無關(guān)緊要?一毫秒和100毫秒在整個(gè)系統(tǒng)中并不重要。
Python最大的優(yōu)點(diǎn)是它可以非常優(yōu)雅地將數(shù)據(jù)拋出到高效的C、CUDA中進(jìn)行計(jì)算。Numpy、panda、numba這些優(yōu)秀的開源庫可以非常方便高效地處理海量數(shù)據(jù),借助ZMQ、cell等還可以做分布式計(jì)算,gevent借助epoll系統(tǒng)IO優(yōu)化。因此,它不需要花費(fèi)太多的精力就可以優(yōu)雅高效地完成海量數(shù)據(jù)處理和機(jī)器學(xué)習(xí)任務(wù)。這就是Python如此流行的原因。
好好想想。同樣的性能,代碼只有CPP或Java的三分之一或更少,不是很吸引人嗎?
29歲想學(xué)python,有哪些建議?
學(xué)習(xí)Python與年齡無關(guān)。去年,我33歲的時(shí)候在openstack上學(xué)習(xí)Python。在我的職業(yè)生涯中,我學(xué)過幾種語言,包括C、C、PHP和python。
就學(xué)習(xí)內(nèi)容而言,我認(rèn)為學(xué)習(xí)一門語言主要包括兩個(gè)方面:
1)語言本身的語法,其實(shí)內(nèi)容很少
2)與語言相關(guān)的系統(tǒng)庫和第三方庫,內(nèi)容多,難度大
另外,我的經(jīng)驗(yàn)是如何學(xué)好一門語言的實(shí)踐,實(shí)踐包括兩個(gè)方面:
1)閱讀更多的代碼,你可以看到更好的開源項(xiàng)目,如openstack或Django等。
2)編寫更多的代碼。如果你的工作中有項(xiàng)目,如果沒有,你可以寫一些小項(xiàng)目。例如,開發(fā)一個(gè)python版本的redis。