目錄
- 一.Python 線程隊(duì)列 Queue 分類(lèi)
- 二.Python 線程優(yōu)先隊(duì)列 PriorityQueue 簡(jiǎn)介
- 三.Python 線程優(yōu)先隊(duì)列 PriorityQueue 函數(shù)介紹
- 四.Python 線程優(yōu)先隊(duì)列 PriorityQueue 使用
- 五.猜你喜歡
零基礎(chǔ) Python 學(xué)習(xí)路線推薦 : Python 學(xué)習(xí)目錄 >> Python 基礎(chǔ)入門(mén)
在 線程隊(duì)列 Queue / 線程隊(duì)列 LifoQueue 文章中分別介紹了先進(jìn)先出隊(duì)列 Queue 和先進(jìn)后出隊(duì)列 LifoQueue ,而今天給大家介紹的是最后一種:優(yōu)先隊(duì)列 PriorityQueue 靶病,對(duì)隊(duì)列中的數(shù)據(jù)按照優(yōu)先級(jí)排序会通,那么具體怎么用呢?
一.Python 線程隊(duì)列 Queue 分類(lèi)
- 1.線程隊(duì)列 Queue — FIFO(先進(jìn)先出隊(duì)列)娄周,即哪個(gè)數(shù)據(jù)先存入涕侈,取數(shù)據(jù)的時(shí)候先取哪個(gè)數(shù)據(jù),同生活中的排隊(duì)買(mǎi)東西煤辨;
- 2.線程隊(duì)列 LifoQueue — LIFO(先進(jìn)后出隊(duì)列)裳涛,即哪個(gè)數(shù)據(jù)最后存入的,取數(shù)據(jù)的時(shí)候先取众辨,同生活中手槍的彈夾端三,子彈最后放入的先打出;
- 3.線程隊(duì)列 PriorityQueue — PriorityQueue(優(yōu)先級(jí)隊(duì)列)鹃彻,即存入數(shù)據(jù)時(shí)候加入一個(gè)優(yōu)先級(jí)郊闯,取數(shù)據(jù)的時(shí)候優(yōu)先級(jí)最高的取出;
二.Python 線程優(yōu)先隊(duì)列 PriorityQueue 簡(jiǎn)介
在數(shù)據(jù)存入的時(shí)候設(shè)置優(yōu)先級(jí)蛛株,取數(shù)據(jù)的時(shí)候默認(rèn)按照優(yōu)先級(jí)最高的取出团赁,注意:使用優(yōu)先級(jí)存數(shù)據(jù)取數(shù)據(jù),隊(duì)列中的數(shù)據(jù)必須是同一類(lèi)型谨履,舉個(gè)栗子:班級(jí)成績(jī)排名/身高排名……
值得注意的是:在將數(shù)據(jù)存入到優(yōu)先隊(duì)列 PriorityQueue 時(shí)然痊,設(shè)置的值越小,優(yōu)先級(jí)越高屉符;
三.Python 線程優(yōu)先隊(duì)列 PriorityQueue 函數(shù)介紹
函數(shù)不做過(guò)多介紹了剧浸,已經(jīng)在 線程隊(duì)列 Queue 有了詳細(xì)講解,兩者都屬于 Queue 矗钟,函數(shù)都一樣唆香!
四.Python 線程優(yōu)先隊(duì)列 PriorityQueue 使用
按優(yōu)先級(jí):不管是數(shù)字、字母吨艇、列表 list 躬它、元組 tuple 等(字典 dict 、集合 set 沒(méi)測(cè))东涡,使用優(yōu)先級(jí)存數(shù)據(jù)取數(shù)據(jù)冯吓,隊(duì)列中的數(shù)據(jù)必須是同一類(lèi)型,都是按照實(shí)際數(shù)據(jù)的 ascii 碼表的順序進(jìn)行優(yōu)先級(jí)匹配疮跑,漢字是按照 unicode 表组贺。
# !usr/bin/env python
# -*- coding:utf-8 _*-
"""
@Author:猿說(shuō)編程
@Blog(個(gè)人博客地址): www.codersrc.com
@File:Python 線程優(yōu)先隊(duì)列 PriorityQueue.py
@Time:2021/05/05 07:37
@Motto:不積跬步無(wú)以至千里,不積小流無(wú)以成江海祖娘,程序人生的精彩需要堅(jiān)持不懈地積累失尖!
"""
import queue
import threading
import time
q = queue.PriorityQueue()
q.put([1, 'ace'])
q.put([40, 333])
q.put([3, 'afd'])
q.put([5, '4asdg'])
# 1是級(jí)別最高的,
while not q.empty(): # 不為空時(shí)候執(zhí)行
print(q.get())
q = queue.PriorityQueue()
q.put('我')
q.put('你')
q.put('他')
q.put('她')
q.put('ta')
while not q.empty():
print(q.get())
'''
輸出結(jié)果:
[1, 'ace']
[3, 'afd']
[5, '4asdg']
[40, 333]
ta
他
你
她
我
'''
** 由此可見(jiàn):在將數(shù)據(jù)存入到優(yōu)先隊(duì)列 PriorityQueue 時(shí),設(shè)置的值越小掀潮,優(yōu)先級(jí)越高!**
五.猜你喜歡
- Python 條件推導(dǎo)式
- Python 列表推導(dǎo)式
- Python 字典推導(dǎo)式
- Python 函數(shù)聲明和調(diào)用
- Python 不定長(zhǎng)參數(shù) *argc/**kargcs
- Python 匿名函數(shù) lambda
- Python return 邏輯判斷表達(dá)式
- Python 字符串/列表/元組/字典之間的相互轉(zhuǎn)換
- Python 局部變量和全局變量
- Python type 函數(shù)和 isinstance 函數(shù)區(qū)別
- Python is 和 == 區(qū)別
- Python 可變數(shù)據(jù)類(lèi)型和不可變數(shù)據(jù)類(lèi)型
- Python 淺拷貝和深拷貝
- Python 文件讀寫(xiě)操作
- Python 異常處理
- Python 模塊 import
- Python __name__ == ‘__main__’詳細(xì)解釋
- Python 線程創(chuàng)建和傳參
- Python 線程互斥鎖 Lock
- Python 線程時(shí)間 Event
- Python 線程條件變量 Condition
- Python 線程定時(shí)器 Timer
- Python 線程信號(hào)量 Semaphore
- Python 線程障礙對(duì)象 Barrier
- Python 線程隊(duì)列 Queue – FIFO
- Python 線程隊(duì)列 LifoQueue – LIFO
- Python 線程優(yōu)先隊(duì)列 PriorityQueue
未經(jīng)允許不得轉(zhuǎn)載:猿說(shuō)編程 ? Python 線程優(yōu)先隊(duì)列 PriorityQueue
本文由博客 - 猿說(shuō)編程 猿說(shuō)編程 發(fā)布菇夸!