2018-11-29 Day19

一.進程和線程的意義

1.進程: 正在執(zhí)行的程序
特點: 相互獨立 占用受保護獨立的內(nèi)存單元

2.線程: 進程想要執(zhí)行任務,必須的有線程
一個進程的所有認為都是在線程中進行的
特點: 串行(一個一個按順序去執(zhí)行任務)

3.多線程
特點: 并行(每條線程可以同時執(zhí)行不同的任務)
原理:
1.同一時間,cpu只能處理一條線程, 只有一條線程在工作.
2.多線程并發(fā)執(zhí)行,其實是cpu在快速地在多線程之間調(diào)度.
3.cpu調(diào)度線程的時間足夠快,造成了多線程并發(fā)的假象.

二.耗時操作

一個進程默認有一個線程,這個線程叫主線程.
默認情況下, 所有的代碼都是在主線程里面進行的.

import time, datetime.

def down_load(film_name):
    print('開始下載%s' % film_name, '開始時間:%s' % datetime.datetime.now())
    time.sleep(5) # 程序執(zhí)行到這個地方,線程會阻塞5秒,再執(zhí)行后面膜的代碼
    print('%s 下載結(jié)束' % film_name,'結(jié)束時間:%s' % datetime.datetime.now())


if __name__ == '__main__':
    down_load('小黃人')
    down_load('地心歷險記')

三.多線程方法1:通過Thread類創(chuàng)建子線程

python通過threading模塊

默認創(chuàng)建的線程叫主線程, 自己創(chuàng)建的線程叫子線程
如果希望代碼在子線程里面執(zhí)行,必須手動創(chuàng)建子線程對象

import threading
import time, datetime

def down_load(film_name):
    print('開始下載%s' % film_name, '開始時間:%s' % datetime.datetime.now())
    time.sleep(5) # 程序執(zhí)行到這個地方,線程會阻塞5秒,再執(zhí)行后面膜的代碼
    print('%s 下載結(jié)束' % film_name,'結(jié)束時間:%s' % datetime.datetime.now())
    print('下載%s' % film_name, threading.current_thread())
if __name__ == '__main__':
    # down_load('小黃人')

    # 1.創(chuàng)建線程對象
    """
    Thread - 線程類
    Thread(target=函數(shù)名, args=參數(shù)列表) - 直接創(chuàng)建線程對象
    函數(shù)名 = 需要在當前線程執(zhí)行的函數(shù)變量
    參數(shù)列表(要求是元組) = 元祖, 元祖的元素是函數(shù)的參數(shù)
    """
    t1 = threading.Thread(target=down_load, args=('小黃人',))
    t2 = threading.Thread(target=down_load, args=('小綠人',))
    # 2. 在子線程中執(zhí)行任務

    """
    這里是調(diào)用down_load函數(shù),并且傳遞一個參數(shù)'小黃人'
    """
    t1.start()
    t2.start()

四.多線程方法2: 通過Thread的子類創(chuàng)建子線程.

import datetime, time, threading
"""
除了直接創(chuàng)建Thread的對象,還可以繼承這個類的對象


注意: 一個進程中有多個線程,進程會在所有的線程都結(jié)束才會結(jié)束
    線程中的任務執(zhí)行完了,線程就結(jié)束
"""

class Thread1(threading.Thread):
    def __init__(self, film_name):
        super().__init__()
        self.film_name = film_name
    # 2.重寫run方法
    def run(self):
        print('開始下載%s' % self.film_name , '開始時間:%s' % datetime.datetime.now())
        time.sleep(5)  # 程序執(zhí)行到這個地方,線程會阻塞5秒,再執(zhí)行后面膜的代碼
        print('%s 下載結(jié)束' % self.film_name , '結(jié)束時間:%s' % datetime.datetime.now())
        print(threading.current_thread())

# 創(chuàng)建線程對象
t1 = Thread1('小黃人')
# 4.通過線程對象調(diào)用start在子線程重執(zhí)行run方法
t1.start()
# 直接調(diào)用run方法會在主線程執(zhí)行

五.join函數(shù)

"""
線程對象.join() - 等待線程對象中的任務執(zhí)行完成
"""
from threading import Thread
import  datetime, time, random

class DownLoad(Thread):
   def __init__(self, film_name):
       super().__init__()
       self.film_name = film_name

   def run(self):
       print('開始下載%s'% self.film_name)
       a = random.randint(5,12)
       time.sleep(a)
       print('下載結(jié)束%s' % self.film_name, '耗時%d秒'% a)

if __name__ == '__main__':
   t1 = DownLoad('小黃人')
   t2 = DownLoad('小綠人')
   time1 = time.time()
   t1.start()
   t2.start()
   # t1和t2的任務都執(zhí)行完成后才會執(zhí)行后面的代碼
   t1.join()
   t2.join()
   time2 = time.time()
   print('總共時間:',str(time2 - time1) + '秒')
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關(guān)閱讀更多精彩內(nèi)容

  • 又來到了一個老生常談的問題,應用層軟件開發(fā)的程序員要不要了解和深入學習操作系統(tǒng)呢? 今天就這個問題開始,來談談操...
    tangsl閱讀 4,317評論 0 23
  • 文/tangsl(簡書作者) 原文鏈接:http://www.itdecent.cn/p/2b993a4b913e...
    西葫蘆炒胖子閱讀 3,935評論 0 5
  • 進程和線程 進程 所有運行中的任務通常對應一個進程,當一個程序進入內(nèi)存運行時,即變成一個進程.進程是處于運行過程中...
    勝浩_ae28閱讀 5,257評論 0 23
  • 現(xiàn)在很多的年輕人都談戀愛 我不知道這是好的還是壞的 很多的年輕人都期待自己有一個由校服走到婚紗的人 但是這條路真的...
    余滄焱閱讀 463評論 0 0
  • 【六項精進打卡】 2018.10.03 姓名:陳崗 企業(yè)名稱:上海孚因流體動力設(shè)備股份有限公司 打卡第163天 【...
    我心依舊_79e2閱讀 138評論 0 0

友情鏈接更多精彩內(nèi)容