通過線程式控制制python程式運行一定時間,線程python程式運行

來源:互聯網
上載者:User

通過線程式控制制python程式運行一定時間,線程python程式運行

<span style="font-family: Arial, Helvetica, sans-serif;">import time</span>
class Test(threading.Thread):    def __init__(self, para):#初始化參數        threading.Thread.__init__(self)        self.para= para        def run(self):        while(True):                  doMail(self.para)#採集if __name__ == "__main__":    para = ""    while True:        msg = Test(para)        msg.setDaemon(True)        msg.start()        msg.join(2)        time.sleep(2)

上例中,用線程去採集,進程裡迴圈啟動線程,每隔2秒,把線程殺死,再重新啟動一個新的線程採集

python中得thread的一些機制和C/C++不同:在C/C++中,主線程結束後,其子線程會預設被主線程kill掉。而在python中,主線程結束後,會預設等待子線程結束後,主線程才退出。

        python對於thread的管理中有兩個函數:join和setDaemon

  • join:如在一個線程B中調用threada.join(),則threada結束後,線程B才會接著threada.join()往後運行。
  • setDaemon:主線程A啟動了子線程B,調用b.setDaemaon(True),則主線程結束時,會把子線程B也殺死,與C/C++中得預設效果是一樣的。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.