백엔드 개발 파이썬 튜토리얼 Python 다중 스레드 프로그래밍 4: 교착 상태 및 재진입 잠금

Python 다중 스레드 프로그래밍 4: 교착 상태 및 재진입 잠금

Oct 18, 2016 am 11:31 AM
멀티스레딩 프로그램 작성

Deadlock

스레드 간에 여러 리소스를 공유할 때 두 스레드가 각각 리소스의 일부를 점유하면서 동시에 서로의 리소스를 기다리면 교착 상태가 발생합니다. 교착 상태는 거의 발생하지 않지만 발생하면 응용 프로그램의 응답이 중지될 수 있습니다. 교착 상태의 예를 살펴보겠습니다.

# encoding: UTF-8
import threading
import time
  
class MyThread(threading.Thread):
    def do1(self):
        global resA, resB
        if mutexA.acquire():
             msg = self.name+' got resA'
             print msg
               
             if mutexB.acquire(1):
                 msg = self.name+' got resB'
                 print msg
                 mutexB.release()
             mutexA.release()
    def do2(self):
        global resA, resB
        if mutexB.acquire():
             msg = self.name+' got resB'
             print msg
               
             if mutexA.acquire(1):
                 msg = self.name+' got resA'
                 print msg
                 mutexA.release()
             mutexB.release()
   
      
    def run(self):
        self.do1()
        self.do2()
resA = 0
resB = 0
  
mutexA = threading.Lock()
mutexB = threading.Lock()
  
def test():
    for i in range(5):
        t = MyThread()
        t.start()
if __name__ == '__main__':
    test()
로그인 후 복사

실행 결과:


Thread-1 got resA

Thread-1 got resB

Thread-1이 resB를 얻었습니다

Thread-1이 resA를 얻었습니다

Thread-2가 resA를 얻었습니다

Thread-2가 resB를 얻었습니다

Thread-2가 resB를 얻었습니다

Thread-2가 resA를 얻었습니다

Thread-3이 resA를 얻었습니다

Thread-3이 resB를 얻었습니다

Thread-3이 resB를 얻었습니다

Thread-3에 resA가 있음

Thread-5에 resA가 있음

Thread-5에 resB가 있음

Thread-5에 resB가 있음

Thread-4가 resA를 얻었습니다


현재 프로세스가 종료되었습니다.


재진입 잠금

더 단순한 교착 상태 상황은 스레드가 동일한 리소스를 요청하기 위해 "반복"하여 교착 상태가 직접적으로 발생하는 경우입니다.

import threading
import time
  
class MyThread(threading.Thread):
    def run(self):
        global num
        time.sleep(1)
  
        if mutex.acquire(1): 
            num = num+1
            msg = self.name+' set num to '+str(num)
            print msg
            mutex.acquire()
            mutex.release()
            mutex.release()
num = 0
mutex = threading.Lock()
def test():
    for i in range(5):
        t = MyThread()
        t.start()
if __name__ == '__main__':
    test()
로그인 후 복사

동일한 스레드에서 동일한 리소스에 대한 여러 요청을 지원하기 위해 Python은 "재진입 잠금"인 threading.RLock을 제공합니다. RLock은 내부적으로 Lock과 카운터 변수를 유지하며, 카운터는 획득 횟수를 기록하므로 리소스가 여러 번 필요할 수 있습니다. 스레드의 모든 획득이 해제될 때까지 다른 스레드가 리소스를 얻을 수 있습니다. 위의 예에서 Lock 대신 RLock을 사용하면 교착 상태가 발생하지 않습니다.

import threading
import time
  
class MyThread(threading.Thread):
    def run(self):
        global num
        time.sleep(1)
  
        if mutex.acquire(1): 
            num = num+1
            msg = self.name+' set num to '+str(num)
            print msg
            mutex.acquire()
            mutex.release()
            mutex.release()
num = 0
mutex = threading.RLock()
def test():
    for i in range(5):
        t = MyThread()
        t.start()
if __name__ == '__main__':
    test()
로그인 후 복사

실행 결과:


Thread-1 set num 1로

Thread-3은 num을 2로 설정

Thread-2는 num을 3으로 설정

Thread-5는 num을 4로 설정

Thread-4 숫자를 5로 설정


본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 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 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

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

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

C++의 멀티스레딩에서 공유 리소스를 처리하는 방법은 무엇입니까? C++의 멀티스레딩에서 공유 리소스를 처리하는 방법은 무엇입니까? Jun 03, 2024 am 10:28 AM

뮤텍스는 C++에서 다중 스레드 공유 리소스를 처리하는 데 사용됩니다. std::mutex를 통해 뮤텍스를 만듭니다. mtx.lock()을 사용하여 뮤텍스를 획득하고 공유 리소스에 대한 독점 액세스를 제공합니다. 뮤텍스를 해제하려면 mtx.unlock()을 사용하세요.

C++에서 멀티스레드 프로그램을 테스트하기 위한 과제와 전략 C++에서 멀티스레드 프로그램을 테스트하기 위한 과제와 전략 May 31, 2024 pm 06:34 PM

다중 스레드 프로그램 테스트는 반복 불가능성, 동시성 오류, 교착 상태 및 가시성 부족과 같은 문제에 직면합니다. 전략은 다음과 같습니다. 단위 테스트: 스레드 동작을 확인하기 위해 각 스레드에 대한 단위 테스트를 작성합니다. 멀티스레드 시뮬레이션: 시뮬레이션 프레임워크를 사용하여 스레드 일정을 제어하여 프로그램을 테스트합니다. 데이터 경합 감지: 도구를 사용하여 valgrind와 같은 잠재적인 데이터 경합을 찾습니다. 디버깅: 디버거(예: gdb)를 사용하여 런타임 프로그램 상태를 검사하고 데이터 경합의 원인을 찾습니다.

멀티스레드 환경에서 C++ 메모리 관리의 과제와 대책은? 멀티스레드 환경에서 C++ 메모리 관리의 과제와 대책은? Jun 05, 2024 pm 01:08 PM

다중 스레드 환경에서 C++ 메모리 관리는 데이터 경합, 교착 상태 및 메모리 누수와 같은 문제에 직면합니다. 대책에는 다음이 포함됩니다. 1. 뮤텍스 및 원자 변수와 같은 동기화 메커니즘을 사용합니다. 2. 잠금 없는 데이터 구조를 사용합니다. 3. 스마트 포인터를 사용합니다. 4. (선택 사항) 가비지 수집을 구현합니다.

C++ 다중 스레드 프로그래밍의 디버깅 및 문제 해결 기술 C++ 다중 스레드 프로그래밍의 디버깅 및 문제 해결 기술 Jun 03, 2024 pm 01:35 PM

C++ 다중 스레드 프로그래밍을 위한 디버깅 기술에는 데이터 경합 분석기를 사용하여 읽기 및 쓰기 충돌을 감지하고 동기화 메커니즘(예: 뮤텍스 잠금)을 사용하여 이를 해결하는 것이 포함됩니다. 스레드 디버깅 도구를 사용하여 교착 상태를 감지하고 중첩된 잠금을 방지하고 교착 상태 감지 메커니즘을 사용하여 교착 상태를 해결합니다. 데이터 경합 분석기를 사용하여 데이터 경합을 감지하고 쓰기 작업을 중요한 섹션으로 이동하거나 원자성 작업을 사용하여 이를 해결합니다. 성능 분석 도구를 사용하여 컨텍스트 전환 빈도를 측정하고 스레드 수를 줄이고 스레드 풀을 사용하며 작업을 오프로드하여 과도한 오버헤드를 해결합니다.

Python을 사용한 문제 해결: 초보 코더로서 강력한 솔루션 잠금 해제 Python을 사용한 문제 해결: 초보 코더로서 강력한 솔루션 잠금 해제 Oct 11, 2024 pm 08:58 PM

Python은 초보자에게 문제 해결 능력을 부여합니다. 사용자 친화적인 구문, 광범위한 라이브러리 및 변수, 조건문 및 루프 사용 효율적인 코드 개발과 같은 기능을 제공합니다. 데이터 관리에서 프로그램 흐름 제어 및 반복 작업 수행에 이르기까지 Python은 제공합니다.

C++ 프로그래밍 퍼즐 모음: 사고를 자극하고 프로그래밍 기술을 향상시킵니다. C++ 프로그래밍 퍼즐 모음: 사고를 자극하고 프로그래밍 기술을 향상시킵니다. Jun 01, 2024 pm 10:26 PM

C++ 프로그래밍 퍼즐은 피보나치 수열, 계승, 해밍 거리, 배열의 최대값과 최소값 등과 같은 알고리즘 및 데이터 구조 개념을 다룹니다. 이러한 퍼즐을 풀면 C++ 지식을 통합하고 알고리즘 이해 및 프로그래밍 기술을 향상시킬 수 있습니다.

C++ 멀티스레드 프로그래밍의 핵심 개념은 스레드를 동기화하는 방법입니다. C++ 멀티스레드 프로그래밍의 핵심 개념은 스레드를 동기화하는 방법입니다. Jun 03, 2024 am 11:55 AM

C++ 다중 스레드 동기화의 주요 개념: 뮤텍스 잠금: 임계 섹션에 하나의 스레드만 액세스할 수 있도록 합니다. 조건 변수: 특정 조건이 충족되면 스레드가 활성화될 수 있습니다. 원자성 작업: 중단할 수 없는 단일 CPU 명령어는 공유 변수 수정의 원자성을 보장합니다.

C++ 다중 스레드 프로그래밍의 교착 상태 방지 및 감지 메커니즘 C++ 다중 스레드 프로그래밍의 교착 상태 방지 및 감지 메커니즘 Jun 01, 2024 pm 08:32 PM

다중 스레드 교착 상태 방지 메커니즘에는 다음이 포함됩니다. 1. 잠금 순서 2. 테스트 및 설정. 감지 메커니즘에는 다음이 포함됩니다. 1. 시간 초과 2. 교착 상태 감지기. 이 기사에서는 공유 은행 계좌의 예를 들어 잠금 시퀀스를 통해 교착 상태를 방지합니다. 이체 기능은 먼저 이체 계좌 잠금을 요청한 다음 계좌 이체를 요청합니다.

See all articles