Python?常用模塊threading和Thread模塊之線程池
1. 池的概念

主線程:
相當于生產(chǎn)者,只管向線程池提交任務(wù)。 并不關(guān)心線程池是如何執(zhí)行任務(wù)的。
線程池:
相當于消費者,負責接收任務(wù),并將任務(wù)分配到一個空閑的線程中去執(zhí)行。并不關(guān)心是哪一個線程執(zhí)行的這個任務(wù)。
2. 自定義線程池
# -*- coding: utf-8 -*-
from threading import Thread
from queue import Queue
import time
class ThreadPool:
# 初始化
def __init__(self, n):
self.queue = Queue()
for i in range(n):
# 創(chuàng)建線程
Thread(target=self.worker, daemon=True).start() #daemon是開啟守護線程
# 執(zhí)行任務(wù)
def worker(self):
while True:
func, args, kwargs = self.queue.get()
func(*args, *kwargs)
self.queue.task_done()
# 獲取任務(wù),將任務(wù)添加到隊列中
def apply_async(self, target, args=(), kwargs={}):
self.queue.put((target, args, kwargs))
# 阻塞
def join(self):
self.queue.join()
def fun(x):
print('愛孤寒者 第%s次' % x)
time.sleep(3)
print('帥哥美女就關(guān)注同名微信公眾號【孤寒者】啦~')
# 開兩個線程
t = ThreadPool(2)
# 提交10個任務(wù)
for i in range(10):
t.apply_async(fun, args=(i,))
t.join()
3. 使用Python內(nèi)置線程池
# -*- coding: utf-8 -*-
from multiprocessing.pool import ThreadPool
import time
pool = ThreadPool(2) # 創(chuàng)建兩個線程
def funa(x, y):
print('%s好好學習' % x)
time.sleep(3)
print('天天向上')
def funb(x, y):
print('%shello' % x)
time.sleep(3)
print('world')
# 我們這就是有一個線程池,里面有兩個等待處理任務(wù)的線程,然后這兩個函數(shù)就是兩個任務(wù),
# 線程池里一個線程處理一個,所以會同時輸出!如果多于兩個任務(wù)就會執(zhí)行等待sleep
pool.apply_async(funa, args=('我們要————', 2)) # 將任務(wù)添加到線程池
pool.apply_async(funb, args=('大家要————', 4))
pool.close() # close之后則無法向線程池提交任務(wù)
# 內(nèi)置線程池,自帶守護線程,主線程結(jié)束,子線程也跟著結(jié)束
# 所以需要加阻塞,否則主線程一結(jié)束,子線程也跟著結(jié)束,無輸出
pool.join() # 在join之前可使用終止線程,直接終止線程pool: pool.terminate()
print('這是程序的最后一行,執(zhí)行到這里,主線程結(jié)束')
4. 池的其他操作
操作一: close - 關(guān)閉提交通道,不允許再提交任務(wù);
操作二: terminate - 中止進程池,中止所有任務(wù) 。
拓展: JSON(JavaScript Object Notation) 是一種輕量級的數(shù)據(jù)交換格式,易于人閱讀和編寫。 是用來存儲和交換文本信息的語法。
數(shù)據(jù)在名稱/值對中 數(shù)據(jù)由逗號分隔 大括號保存對象 中括號保存數(shù)組
使用 JSON 函數(shù)需要導(dǎo)入 json 庫:import json。
json,用于字符串 和 python數(shù)據(jù)類型間進行轉(zhuǎn)換json模塊提供了四個功能:dumps、dump、loads、load
- 1.json.dumps 將 Python 對象編碼成 JSON 數(shù)據(jù)
- 2.json.dump 將 JSON 數(shù)據(jù)通過特殊的形式轉(zhuǎn)換為只有 Python 認識的字符串并寫入文件
- 3.json.loads 將已編碼的 JSON 數(shù)據(jù)解碼為 Python 對象
- 4.json.load 將一個包含 JSON 格式數(shù)據(jù)的可讀文件解碼為一個 Python 對象并寫入文件
到此這篇關(guān)于Python 常用模塊threading和Thread模塊之線程池的文章就介紹到這了,更多相關(guān)Python線程池內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
對python中兩種列表元素去重函數(shù)性能的比較方法
今天小編就為大家分享一篇對python中兩種列表元素去重函數(shù)性能的比較方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-06-06
Python腳本在Appium庫上對移動應(yīng)用實現(xiàn)自動化測試
這篇文章主要介紹了使用Python的Appium庫對移動應(yīng)用實現(xiàn)自動化測試的教程,屬于Python腳本的一個自動化應(yīng)用,需要的朋友可以參考下2015-04-04
給Python學習者的文件讀寫指南(含基礎(chǔ)與進階)
今天,貓貓跟大家一起,好好學習Python文件讀寫的內(nèi)容,這部分內(nèi)容特別常用,掌握后對工作和實戰(zhàn)都大有益處,學習是循序漸進的過程,欲速則不達2020-01-01

