목차
Queue
기본 FIFO 대기열
LIFO queue
优先级队列
一些常用方法
task_done()
join()
put(item[, block[, timeout]])
get([block[, timeout]])
class Queue.PriorityQueue(maxsize=0)
백엔드 개발 파이썬 튜토리얼 Python의 대기열 모듈에 대한 자세한 설명

Python의 대기열 모듈에 대한 자세한 설명

Jul 19, 2017 pm 01:16 PM
python queue 대기줄

Queue

Queue는 Python 표준 라이브러리의 FIFO(스레드 안전 큐) 구현으로, 멀티스레드 프로그래밍에 적합한 선입선출 데이터 구조, 즉 생산자와 생산자 간에 사용되는 큐를 제공합니다. 소비자 스레드. 정보 전송

기본 FIFO 대기열

class Queue.Queue(maxsize=0)

FIFO는 선입선출입니다. 큐는 사용이 매우 간단한 기본 FIFO 컨테이너를 제공합니다. maxsize는 큐에 저장할 수 있는 데이터 수의 상한을 지정하는 정수입니다. 제한에 도달하면 대기열의 데이터가 소비될 때까지 삽입으로 인해 차단이 발생합니다. maxsize가 0보다 작거나 같으면 대기열 크기에 제한이 없습니다.

예:

1 import Queue2 3 q = Queue.Queue()4 5 for i in range(5):6     q.put(i)7 8 while not q.empty():9     print q.get()
로그인 후 복사

출력:

01
2
3
4
로그인 후 복사

LIFO queue

class Queue.LifoQueue(maxsize=0)

LIFO는 후입 우선, 후입 우선입니다. 밖으로 . 스택과 유사하게 maxsize의 사용법은 위와 동일합니다. 또 다른 예:

1 import Queue2 3 q = Queue.LifoQueue()4 5 for i in range(5):6     q.put(i)7 8 while not q.empty():9     print q.get()
로그인 후 복사

출력:

4
3
2
10
로그인 후 복사

만 볼 수 있습니다. Queue.Quenu 클래스Queue.LifiQueue 클래스로 대체

Priority QueueQueue.Quenu类替换为Queue.LifiQueue类

优先级队列

class Queue.PriorityQueue(maxsize=0)

构造一个优先队列。maxsize用法同上。

import Queueimport threadingclass Job(object):def __init__(self, priority, description):
        self.priority = priority
        self.description = descriptionprint 'Job:',descriptionreturndef __cmp__(self, other):return cmp(self.priority, other.priority)

q = Queue.PriorityQueue()

q.put(Job(3, 'level 3 job'))
q.put(Job(10, 'level 10 job'))
q.put(Job(1, 'level 1 job'))def process_job(q):while True:
        next_job = q.get()print 'for:', next_job.description
        q.task_done()

workers = [threading.Thread(target=process_job, args=(q,)),
        threading.Thread(target=process_job, args=(q,))
        ]for w in workers:
    w.setDaemon(True)
    w.start()

q.join()
结果
Job: level 3 job
Job: level 10 job
Job: level 1 jobfor: level 1 jobfor: level 3 jobfor: job: level 10 job
로그인 후 복사

 

一些常用方法

task_done()

意味着之前入队的一个任务已经完成。由队列的消费者线程调用。每一个get()调用得到一个任务,接下来的task_done()调用告诉队列该任务已经处理完毕。

如果当前一个join()正在阻塞,它将在队列中的所有任务都处理完时恢复执行(即每一个由put()调用入队的任务都有一个对应的task_done()调用)。

join()

阻塞调用线程,直到队列中的所有任务被处理掉。

只要有数据被加入队列,未完成的任务数就会增加。当消费者线程调用task_done()(意味着有消费者取得任务并完成任务),未完成的任务数就会减少。当未完成的任务数降到0,join()解除阻塞。

put(item[, block[, timeout]])

将item放入队列中。

  1. 如果可选的参数block为True且timeout为空对象(默认的情况,阻塞调用,无超时)。

  2. 如果timeout是个正整数,阻塞调用进程最多timeout秒,如果一直无空空间可用,抛出Full异常(带超时的阻塞调用)。

  3. 如果block为False,如果有空闲空间可用将数据放入队列,否则立即抛出Full异常

其非阻塞版本为put_nowait等同于put(item, False)

get([block[, timeout]])

从队列中移除并返回一个数据。block跟timeout参数同put方法

其非阻塞方法为`get_nowait()`相当与get(False)

class Queue.PriorityQueue(maxsize=0)

우선순위 큐를 구성합니다. maxsize의 사용법은 위와 동일합니다. 🎜🎜rrreee🎜🎜 🎜🎜몇 가지 일반적인 방법 🎜🎜🎜task_done()🎜🎜🎜은 이전에 대기 중인 작업이 완료되었음을 의미합니다. 대기열의 소비자 스레드에 의해 호출됩니다. 각 get() 호출은 작업을 가져오고 다음 task_done() 호출은 작업이 처리되었음을 대기열에 알립니다. 🎜🎜현재 Join()이 차단 중인 경우 대기열의 모든 작업이 처리되면 실행이 재개됩니다(즉, put() 호출로 대기열에 추가된 각 작업에는 해당 task_done() 호출이 있습니다). 🎜🎜🎜join()🎜🎜🎜은 대기열의 모든 작업이 처리될 때까지 호출 스레드를 차단합니다. 🎜🎜큐에 데이터가 추가되는 한 완료되지 않은 작업 수가 늘어납니다. 소비자 스레드가 task_done()(소비자가 작업을 획득하고 작업을 완료함을 의미)을 호출하면 완료되지 않은 작업 수가 줄어듭니다. 완료되지 않은 작업 수가 0으로 떨어지면 Join()이 차단을 해제합니다. 🎜🎜🎜put(item[, block[, timeout]])🎜🎜🎜항목을 대기열에 넣습니다. 🎜
  1. 🎜선택적 매개변수 블록이 True이고 timeout이 빈 개체인 경우(기본값, 호출 차단, 시간 초과 없음). 🎜
  2. 🎜timeout이 양의 정수인 경우 호출 프로세스는 최대 timeout 초 동안 차단됩니다. 사용 가능한 여유 공간이 없으면 전체 예외(시간 초과로 호출 차단)가 발생합니다. 🎜
  3. 🎜block이 False인 경우 사용 가능한 여유 공간이 있으면 데이터를 큐에 넣습니다. 그렇지 않으면 전체 예외가 즉시 발생합니다🎜
🎜비차단 버전 put_nowait put(item, False)🎜🎜🎜get([block[, timeout]])🎜🎜🎜과 동일합니다. 대기열에서 제거하고 데이터 조각을 반환합니다. . 블록 및 시간 초과 매개변수는 put 메서드와 동일합니다🎜🎜비차단 메서드는 `get_nowait()`이며 이는 get(False)🎜🎜empty와 동일합니다. ()🎜🎜큐가 비어 있으면 True를 반환하고, 그렇지 않으면 False를 반환합니다🎜

위 내용은 Python의 대기열 모듈에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

템플릿의 장점과 단점은 무엇입니까? 템플릿의 장점과 단점은 무엇입니까? May 08, 2024 pm 03:51 PM

템플릿의 장점과 단점은 무엇입니까?

Google AI, 개발자를 위한 Gemini 1.5 Pro 및 Gemma 2 발표 Google AI, 개발자를 위한 Gemini 1.5 Pro 및 Gemma 2 발표 Jul 01, 2024 am 07:22 AM

Google AI, 개발자를 위한 Gemini 1.5 Pro 및 Gemma 2 발표

DeepSeek Xiaomi를 다운로드하는 방법 DeepSeek Xiaomi를 다운로드하는 방법 Feb 19, 2025 pm 05:27 PM

DeepSeek Xiaomi를 다운로드하는 방법

당신은 그에게 Deepseek에게 어떻게 물어 봐요 당신은 그에게 Deepseek에게 어떻게 물어 봐요 Feb 19, 2025 pm 04:42 PM

당신은 그에게 Deepseek에게 어떻게 물어 봐요

평가 기능을 저장하는 방법 평가 기능을 저장하는 방법 May 07, 2024 am 01:09 AM

평가 기능을 저장하는 방법

NET40은 어떤 소프트웨어인가요? NET40은 어떤 소프트웨어인가요? May 10, 2024 am 01:12 AM

NET40은 어떤 소프트웨어인가요?

DeepSeek을 검색하는 방법 DeepSeek을 검색하는 방법 Feb 19, 2025 pm 05:18 PM

DeepSeek을 검색하는 방법

브라우저 플러그인은 어떤 언어로 작성되어 있나요? 브라우저 플러그인은 어떤 언어로 작성되어 있나요? May 08, 2024 pm 09:36 PM

브라우저 플러그인은 어떤 언어로 작성되어 있나요?

See all articles