스레드 구현

이 장에서는 파이썬에서 스레드를 구현하는 방법을 배웁니다.

스레드 구현을위한 Python 모듈

Python 스레드는 스레드가 프로세스보다 훨씬 적은 메모리를 차지하기 때문에 경량 프로세스라고도합니다. 스레드를 사용하면 한 번에 여러 작업을 수행 할 수 있습니다. Python에는 프로그램에서 스레드를 구현하는 다음 두 개의 모듈이 있습니다.

  • <_thread>module

  • <threading>module

이 두 모듈의 주요 차이점은 <_thread> 모듈은 스레드를 함수로 취급하는 반면, <threading>모듈은 모든 스레드를 객체로 취급하고 객체 지향 방식으로 구현합니다. 또한<_thread>모듈은 낮은 수준의 스레딩에 효과적이며 <threading> 기준 치수.

<_thread> 모듈

이전 버전의 Python에서는 <thread>모듈이지만 꽤 오랫동안 "사용되지 않는"것으로 간주되었습니다. 사용자는<threading>모듈 대신. 따라서 Python 3에서는 "thread"모듈을 더 이상 사용할 수 없습니다. 이름이 "로 변경되었습니다.<_thread>"는 Python3의 하위 호환성 문제입니다.

의 도움으로 새 스레드를 생성하려면 <_thread> 모듈을 호출해야합니다. start_new_thread그것의 방법. 이 방법의 작동은 다음 구문의 도움으로 이해할 수 있습니다.

_thread.start_new_thread ( function, args[, kwargs] )

여기-

  • args 인수의 튜플입니다.

  • kwargs 키워드 인수의 선택적 사전입니다.

인수를 전달하지 않고 함수를 호출하려면 빈 인수 튜플을 사용해야합니다. args.

이 메서드 호출은 즉시 반환되고 자식 스레드가 시작되며 전달 된 인수 목록 (있는 경우)과 함께 함수를 호출합니다. 스레드는 함수가 반환 될 때 종료됩니다.

다음은 다음을 사용하여 새 스레드를 생성하는 예입니다. <_thread>기준 치수. 여기서는 start_new_thread () 메서드를 사용하고 있습니다.

import _thread
import time

def print_time( threadName, delay):
   count = 0
   while count < 5:
      time.sleep(delay)
      count += 1
      print ("%s: %s" % ( threadName, time.ctime(time.time()) ))

try:
   _thread.start_new_thread( print_time, ("Thread-1", 2, ) )
   _thread.start_new_thread( print_time, ("Thread-2", 4, ) )
except:
   print ("Error: unable to start thread")
while 1:
   pass

산출

다음 출력은 새 스레드의 생성을 이해하는 데 도움이됩니다. <_thread> 기준 치수.

Thread-1: Mon Apr 23 10:03:33 2018
Thread-2: Mon Apr 23 10:03:35 2018
Thread-1: Mon Apr 23 10:03:35 2018
Thread-1: Mon Apr 23 10:03:37 2018
Thread-2: Mon Apr 23 10:03:39 2018
Thread-1: Mon Apr 23 10:03:39 2018
Thread-1: Mon Apr 23 10:03:41 2018
Thread-2: Mon Apr 23 10:03:43 2018
Thread-2: Mon Apr 23 10:03:47 2018
Thread-2: Mon Apr 23 10:03:51 2018

<threading> 모듈

그만큼 <threading>모듈은 객체 지향 방식으로 구현하고 모든 스레드를 객체로 취급합니다. 따라서 <_thread> 모듈보다 훨씬 더 강력하고 높은 수준의 스레드 지원을 제공합니다. 이 모듈은 Python 2.4에 포함되어 있습니다.

<threading> 모듈의 추가 메서드

그만큼 <threading> 모듈은 모든 방법을 포함합니다 <_thread>모듈이지만 추가 메소드도 제공합니다. 추가 방법은 다음과 같습니다.

  • threading.activeCount() −이 메서드는 활성 상태 인 스레드 개체의 수를 반환합니다.

  • threading.currentThread() −이 메서드는 호출자의 스레드 제어에있는 스레드 개체의 수를 반환합니다.

  • threading.enumerate() −이 메서드는 현재 활성화 된 모든 스레드 개체의 목록을 반환합니다.

  • 스레딩을 구현하려면 <threading> 모듈에는 Thread 다음 메소드를 제공하는 클래스-

    • run() − run () 메서드는 스레드의 진입 점입니다.

    • start() − start () 메서드는 run 메서드를 호출하여 스레드를 시작합니다.

    • join([time]) − join ()은 스레드가 종료되기를 기다립니다.

    • isAlive() − isAlive () 메서드는 스레드가 여전히 실행 중인지 확인합니다.

    • getName() − getName () 메서드는 스레드의 이름을 반환합니다.

    • setName() − setName () 메서드는 스레드의 이름을 설정합니다.

<threading> 모듈을 사용하여 스레드를 만드는 방법은 무엇입니까?

이 섹션에서는 다음을 사용하여 스레드를 만드는 방법을 배웁니다. <threading>기준 치수. 다음 단계에 따라 <threading> 모듈을 사용하여 새 스레드를 만듭니다.

  • Step 1 −이 단계에서는 새로운 하위 클래스를 정의해야합니다. Thread 수업.

  • Step 2 − 그런 다음 추가 인수를 추가하려면 __init__(self [,args]) 방법.

  • Step 3 −이 단계에서는 스레드가 시작될 때 수행해야하는 작업을 구현하기 위해 run (self [, args]) 메서드를 재정의해야합니다.

  • 이제 새로 만든 후 Thread 하위 클래스에서 인스턴스를 만든 다음 새 스레드를 시작할 수 있습니다. start(), 차례로 run() 방법.

이 예제를 사용하여 새 스레드를 생성하는 방법을 알아보십시오. <threading> 기준 치수.

import threading
import time
exitFlag = 0

class myThread (threading.Thread):
   def __init__(self, threadID, name, counter):
      threading.Thread.__init__(self)
      self.threadID = threadID
      self.name = name
      self.counter = counter
   def run(self):
      print ("Starting " + self.name)
      print_time(self.name, self.counter, 5)
      print ("Exiting " + self.name)
def print_time(threadName, delay, counter):
   while counter:
      if exitFlag:
         threadName.exit()
      time.sleep(delay)
      print ("%s: %s" % (threadName, time.ctime(time.time())))
      counter -= 1

thread1 = myThread(1, "Thread-1", 1)
thread2 = myThread(2, "Thread-2", 2)

thread1.start()
thread2.start()
thread1.join()
thread2.join()
print ("Exiting Main Thread")
Starting Thread-1
Starting Thread-2

산출

이제 다음 출력을 고려하십시오.

Thread-1: Mon Apr 23 10:52:09 2018
Thread-1: Mon Apr 23 10:52:10 2018
Thread-2: Mon Apr 23 10:52:10 2018
Thread-1: Mon Apr 23 10:52:11 2018
Thread-1: Mon Apr 23 10:52:12 2018
Thread-2: Mon Apr 23 10:52:12 2018
Thread-1: Mon Apr 23 10:52:13 2018
Exiting Thread-1
Thread-2: Mon Apr 23 10:52:14 2018
Thread-2: Mon Apr 23 10:52:16 2018
Thread-2: Mon Apr 23 10:52:18 2018
Exiting Thread-2
Exiting Main Thread

다양한 스레드 상태를위한 Python 프로그램

스레드 상태에는 새, 실행 가능, 실행 중, 대기 중 및 종료의 다섯 가지가 있습니다. 이 5 개 중 5 개 중 주로 달리기, 대기 중, 사망의 세 가지 상태에 초점을 맞출 것입니다. 스레드는 실행 상태의 리소스를 가져오고 대기 상태의 리소스를 기다립니다. 리소스의 최종 릴리스 (실행되고 획득 된 경우)가 데드 상태에 있습니다.

start (), sleep () 및 join () 메서드를 사용하는 다음 Python 프로그램은 스레드가 각각 실행 중, 대기 중 및 사용 불능 상태에 들어간 방법을 보여줍니다.

Step 1 − 필요한 모듈, <threading> 및 <time> 가져 오기

import threading
import time

Step 2 − 스레드를 생성하는 동안 호출 될 함수를 정의합니다.

def thread_states():
   print("Thread entered in running state")

Step 3 − time 모듈의 sleep () 메서드를 사용하여 스레드가 2 초 동안 대기하도록합니다.

time.sleep(2)

Step 4 − 이제 위에서 정의한 함수의 인수를받는 T1이라는 스레드를 생성합니다.

T1 = threading.Thread(target=thread_states)

Step 5− 이제 start () 함수의 도움으로 스레드를 시작할 수 있습니다. 기능을 정의하는 동안 우리가 설정 한 메시지를 생성합니다.

T1.start()
Thread entered in running state

Step 6 − 이제 드디어 실행을 마친 후 join () 메소드로 스레드를 종료 할 수 있습니다.

T1.join()

Python에서 스레드 시작

파이썬에서는 다른 방법으로 새 ​​스레드를 시작할 수 있지만 그중 가장 쉬운 방법은 단일 함수로 정의하는 것입니다. 함수를 정의한 후이를 새로운 대상으로 전달할 수 있습니다.threading.Thread개체 등등. 함수가 어떻게 작동하는지 이해하려면 다음 Python 코드를 실행하십시오.

import threading
import time
import random
def Thread_execution(i):
   print("Execution of Thread {} started\n".format(i))
   sleepTime = random.randint(1,4)
   time.sleep(sleepTime)
   print("Execution of Thread {} finished".format(i))
for i in range(4):
   thread = threading.Thread(target=Thread_execution, args=(i,))
   thread.start()
   print("Active Threads:" , threading.enumerate())

산출

Execution of Thread 0 started
Active Threads:
   [<_MainThread(MainThread, started 6040)>,
      <HistorySavingThread(IPythonHistorySavingThread, started 5968)>,
      <Thread(Thread-3576, started 3932)>]

Execution of Thread 1 started
Active Threads:
   [<_MainThread(MainThread, started 6040)>,
      <HistorySavingThread(IPythonHistorySavingThread, started 5968)>,
      <Thread(Thread-3576, started 3932)>,
      <Thread(Thread-3577, started 3080)>]

Execution of Thread 2 started
Active Threads:
   [<_MainThread(MainThread, started 6040)>,
      <HistorySavingThread(IPythonHistorySavingThread, started 5968)>,
      <Thread(Thread-3576, started 3932)>,
      <Thread(Thread-3577, started 3080)>,
      <Thread(Thread-3578, started 2268)>]

Execution of Thread 3 started
Active Threads:
   [<_MainThread(MainThread, started 6040)>,
      <HistorySavingThread(IPythonHistorySavingThread, started 5968)>,
      <Thread(Thread-3576, started 3932)>,
      <Thread(Thread-3577, started 3080)>,
      <Thread(Thread-3578, started 2268)>,
      <Thread(Thread-3579, started 4520)>]
Execution of Thread 0 finished
Execution of Thread 1 finished
Execution of Thread 2 finished
Execution of Thread 3 finished

Python의 데몬 스레드

파이썬에서 데몬 스레드를 구현하기 전에 데몬 스레드와 그 사용법에 대해 알아야합니다. 컴퓨팅 측면에서 데몬은 데이터 전송, 파일 전송 등과 같은 다양한 서비스에 대한 요청을 처리하는 백그라운드 프로세스입니다. 더 이상 필요하지 않으면 휴면 상태가됩니다. 데몬이 아닌 스레드의 도움으로 동일한 작업을 수행 할 수도 있습니다. 그러나이 경우 주 스레드는 데몬이 아닌 스레드를 수동으로 추적해야합니다. 반면에 데몬 스레드를 사용하는 경우 메인 스레드는이를 완전히 잊을 수 있으며 메인 스레드가 종료되면 종료됩니다. 데몬 스레드에 대한 또 다른 중요한 점은 완료되지 않거나 중간에 죽어도 영향을주지 않는 중요하지 않은 작업에만 사용하도록 선택할 수 있다는 것입니다. 다음은 파이썬에서 데몬 스레드의 구현입니다-

import threading
import time

def nondaemonThread():
   print("starting my thread")
   time.sleep(8)
   print("ending my thread")
def daemonThread():
   while True:
   print("Hello")
   time.sleep(2)
if __name__ == '__main__':
   nondaemonThread = threading.Thread(target = nondaemonThread)
   daemonThread = threading.Thread(target = daemonThread)
   daemonThread.setDaemon(True)
   daemonThread.start()
   nondaemonThread.start()

위의 코드에는 두 가지 기능이 있습니다. >nondaemonThread()>daemonThread(). 첫 번째 함수는 상태를 인쇄하고 8 초 후에 휴면하는 반면 deamonThread () 함수는 2 초마다 무기한으로 Hello를 인쇄합니다. 다음 출력을 통해 nondaemon과 daemon 스레드의 차이점을 이해할 수 있습니다.

Hello

starting my thread
Hello
Hello
Hello
Hello
ending my thread
Hello
Hello
Hello
Hello
Hello