Python에서 스레드를 생성할 때 start( ) 방법. 그러나 스레드 생성 구문 내에서 대상 함수가 호출되는 상황에서는 흥미로운 문제가 발생합니다.
고려하세요. 다음 코드 조각:
t1 = threading.Thread(target=self.read()) print("something") t2 = threading.Thread(target=self.runChecks(), args=(self,))
놀랍게도 self.read가 무한정 실행되어 프로그램이 다음 줄에 도달하지 못하도록 하기 때문에 print 문은 실행되지 않습니다. t1.start()를 호출하면 스레드 실행이 시작되고 프로그램이 계속 진행되도록 허용해야 하기 때문에 이 동작은 직관에 어긋나는 것처럼 보입니다.
문제는 self.read() 뒤의 괄호에 있습니다. Python에서는 함수 바로 뒤의 괄호가 함수를 호출하므로 다음 코드는
target=self.read()
실제로 self.read를 호출하고 반환 값을 대상 인수로 Thread에 전달합니다. 그러나 Thread는 반환 값이 아닌 함수 참조를 기대합니다. 동작을 수정하려면 스레드 생성 후 괄호를 제거하고 명시적으로 t1.start()를 호출하면 됩니다.
t1 = threading.Thread(target=self.read) t1.start() print("something")
대상 함수에 인수가 필요하면 threading.Thread에 args 또는 kwargs 인수를 사용하세요. 또는 아래와 같이 람다 함수를 사용합니다.
thread = threading.Thread(target=f, args=(a, b), kwargs={'x': c})
또는
thread = threading.Thread(target=lambda: f(a, b, x=c))
람다를 사용하는 경우 함수의 인수는 람다가 호출될 때 평가되는 것이 아니라 호출될 때 평가됩니다. 정의되어 있습니다. 스레드 예약 전에 변수를 다시 할당하면 예상치 못한 결과가 발생할 수 있습니다.
위 내용은 Python에서 스레드를 명시적으로 호출하지 않으면 스레드 실행이 비정상적으로 발생하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!