新聞中心
Python應(yīng)用程序?yàn)橛脩籼峁┝嗽S多強(qiáng)大的圖形處理的能力,并提供廣泛的圖形文件格式支持,通過(guò)它就可在zope中連接mysql數(shù)據(jù)庫(kù),希望本文能夠給大家?guī)?lái)自己想要的信息。

創(chuàng)新互聯(lián)建站長(zhǎng)期為近1000家客戶提供的網(wǎng)站建設(shè)服務(wù),團(tuán)隊(duì)從業(yè)經(jīng)驗(yàn)10年,關(guān)注不同地域、不同群體,并針對(duì)不同對(duì)象提供差異化的產(chǎn)品和服務(wù);打造開(kāi)放共贏平臺(tái),與合作伙伴共同營(yíng)造健康的互聯(lián)網(wǎng)生態(tài)環(huán)境。為崇陽(yáng)企業(yè)提供專業(yè)的成都網(wǎng)站設(shè)計(jì)、網(wǎng)站建設(shè),崇陽(yáng)網(wǎng)站改版等技術(shù)服務(wù)。擁有十載豐富建站經(jīng)驗(yàn)和眾多成功案例,為您定制開(kāi)發(fā)。
這個(gè)方法基本和join是相反的。當(dāng)我們?cè)诔绦蜻\(yùn)行中,執(zhí)行一個(gè)主線程,如果主線程又創(chuàng)建一個(gè)子線程,主線程和子線程就分兵兩路。分別運(yùn)行,那么當(dāng)主線程完成想退出時(shí),會(huì)檢驗(yàn)子線程是否完成。如果子線程未完成,則主線程會(huì)等待子線程完成后再退出。
但是有時(shí)候我們需要的是,只要主線程完成了,不管子線程是否完成,都要和主線程一起退出,這時(shí)就可以用setDaemon方法啦。如果你要?jiǎng)?chuàng)建一個(gè)線程對(duì)象,很簡(jiǎn)單,只要你的類繼承Python應(yīng)用程序,然后在__init__里首先調(diào)用threading.Thread的__init__方法即可:
這才僅僅是個(gè)空線程,我可不是要他拉空車的,他可得給我干點(diǎn)實(shí)在活。很簡(jiǎn)單,重寫(xiě)類的run()方法即可,把你要在線程執(zhí)行時(shí)做的事情都放到里面。以上代碼我們讓這個(gè)線程在執(zhí)行之后每隔1秒輸出一次信息到屏幕,10次后結(jié)束getName()是threading.Thread類的一個(gè)方法,用來(lái)獲得這個(gè)線程對(duì)象的name。還有一個(gè)方法setName()當(dāng)然就是來(lái)設(shè)置這個(gè)線程對(duì)象的name的了。
Python應(yīng)用程序不是已經(jīng)start了嗎?為什么不稱為“running”狀態(tài)呢?其實(shí)是有原因的。因?yàn)槲覀兊挠?jì)算機(jī)一般是不具有真正并行處理能力的。我們所謂的多線程只是把時(shí)間分成片段,然后隔一個(gè)時(shí)間段就讓一個(gè)線程執(zhí)行一下,然后進(jìn)“sleeping ”狀態(tài),然后喚醒另一個(gè)在“sleeping”的線程。
如此循環(huán)runnable->sleeping->runnable... ,只是因?yàn)橛?jì)算機(jī)執(zhí)行速度很快,而時(shí)間片段間隔很小,我們感受不到,以為是同時(shí)進(jìn)行的。所以說(shuō)一個(gè)線程在start了之后只是處在了可以運(yùn)行的狀態(tài),他什么時(shí)候運(yùn)行還是由系統(tǒng)來(lái)進(jìn)行調(diào)度的。那一個(gè)線程什么時(shí)候會(huì)“dead”呢?
一般來(lái)說(shuō)當(dāng)線程對(duì)象的run方法執(zhí)行結(jié)束或者在執(zhí)行中拋出異常的話,那么這個(gè)線程就會(huì)結(jié)束了。系統(tǒng)會(huì)自動(dòng)對(duì)“dead”狀態(tài)線程進(jìn)行清理。
- import threading
- import time
- class myThread(threading.Thread):
- def __init__(self,threadname):
- threading.Thread.__init__(self,name=threadname)
- def run(self):
- time.sleep(5)
- print self.getName()
- def fun1():
- t1.start()
- print 'fun1 done'
- def fun2():
- t2.start()
- print 'fun2 done'
- t1=myThread('t1')
- t2=myThread('t2')
- t2.setDaemon(True)
- fun1()
- fun2()
- 上面這個(gè)例子,按照我們?cè)O(shè)想的輸出時(shí):
- fun1 done
- fun2 done
- t1
但是實(shí)際上我們?cè)诮换ツJ?,主線程只有在Python應(yīng)用程序退出時(shí)終止,所以結(jié)果t2也是被打印出來(lái)啦。
分享文章:有關(guān)Python應(yīng)用程序進(jìn)行解讀學(xué)習(xí)
網(wǎng)頁(yè)網(wǎng)址:http://m.5511xx.com/article/cdjejco.html


咨詢
建站咨詢
