python是時(shí)下最熱門的編程語(yǔ)言之一了。簡(jiǎn)潔而富有表達(dá)力的語(yǔ)法,兩三行代碼往往就能解決十來(lái)行C代碼才能解決的問(wèn)題;豐富的標(biāo)準(zhǔn)庫(kù)和第三方庫(kù),大大節(jié)約了開發(fā)時(shí)間,使它成為那些對(duì)性能沒有嚴(yán)苛要求的開發(fā)任務(wù)的首選;強(qiáng)大而活躍的社區(qū),齊全的文檔,也使很多編程的初學(xué)者選擇了它作為自己的第一門編程語(yǔ)言。甚至有國(guó)外的報(bào)道稱,Python已經(jīng)成為了美國(guó)頂尖大學(xué)里最受歡迎的編程入門教學(xué)語(yǔ)言。
要學(xué)好一門編程語(yǔ)言實(shí)屬不易,在初學(xué)階段,就糾正一些錯(cuò)誤的做法,對(duì)今后的深入學(xué)習(xí)至關(guān)重要。有一位叫ConstantineLignos的博主,他是賓夕法尼亞兒童醫(yī)院放射研究部門的博士后研究員,他最近撰寫了一篇很有意義的文章,列舉了初學(xué)Python的學(xué)生們最常犯的錯(cuò)誤,并對(duì)這些錯(cuò)誤進(jìn)行了分類和剖析,其內(nèi)容提綱挈領(lǐng),非常值得每個(gè)Python初學(xué)者學(xué)習(xí)。
這篇文章給出了一些在Python初學(xué)者中很常見的反模式,反模式通常是指那些不符合習(xí)慣或者會(huì)導(dǎo)致糟糕后果的用法。Lignos把他總結(jié)的反模式分成了四大類——迭代、性能、變量的漏洞和編程風(fēng)格。下面我們逐一來(lái)看一個(gè)例子,理解這些反模式到底“反”在什么地方。
迭代
當(dāng)我們需要簡(jiǎn)單迭代一個(gè)數(shù)量范圍的時(shí)候,Python給了我們一個(gè)非常好用的函數(shù):range。Lignos觀察到有些初學(xué)者喜歡用range來(lái)迭代列表的下表,像下面這種形式:
foriinrange(len(alist)):
printalist[i]
這代碼現(xiàn)在還沒什么問(wèn)題,但已經(jīng)不符合Python的習(xí)慣了。但下面的代碼就有問(wèn)題了:
alist=['her','name','is','rio']
foriinrange(0,len(alist)-1):#漏掉了最后一個(gè)
printi,alist[i]
我們可以看一下Python官方文檔range的示例:
>>>range(1,11)
[1,2,3,4,5,6,7,8,9,10]
range的右區(qū)間是不包含在內(nèi)的,如果受了直覺或其他編程語(yǔ)言的影響,再減1就不對(duì)了。Lignos還列舉了其他幾種錯(cuò)誤的迭代模式,我們只要記住,range應(yīng)該用在迭代一個(gè)數(shù)量范圍。
性能
Lignos給出了兩段代碼:
lyrics_list=['her','name','is','rio']
words=make_wordlist()
forwordinwords:
ifwordinlyrics_list:#線性時(shí)間
printword,"isinthelyrics"
和
lyrics_set=set(lyrics_list)
words=make_wordlist()
forwordinwords:
ifwordinlyrics_set:#常數(shù)時(shí)間
printword,"isinthelyrics"
哪種模式效率更高?Lignos注釋已經(jīng)給出了答案。注釋的意思是,判斷一個(gè)元素是否在一組元素中存在,使用list的算法復(fù)雜度是O(n),而使用set的算法復(fù)雜度是O(1)。那是否set永遠(yuǎn)是優(yōu)于list?在其他情況下,應(yīng)該用哪個(gè)數(shù)據(jù)結(jié)構(gòu)?Python官方Wiki有一份專門各個(gè)數(shù)據(jù)結(jié)構(gòu)操作的時(shí)間復(fù)雜度的文檔供參考,知道參考這份文檔比答案本身更重要。至于為什么,只有Python的源碼才能告訴我們。
以上內(nèi)容為大家介紹了Python編程中的反模式,希望對(duì)大家有所幫助,如果想要了解更多Python相關(guān)知識(shí),請(qǐng)關(guān)注IT培訓(xùn)機(jī)構(gòu):千鋒教育。http://m.2667701.com/