다양한 운영 체제에서 동기화된 변수의 다양한 동작
SEO:
- Python 동기화 변수 값은 전역 컨텍스트에서 변경되지 않습니다
- 메인 프로세스에서는 동기화된 값이 수정되지 않습니다
- 프로세스 간 동기화된 값은 공유되지 않습니다
Python의 다중 처리 라이브러리에는 서로 다른 프로세스 간에 데이터를 공유하는 데 사용되는 래퍼 유형인 multiprocessing.sharedctypes.synchronized가 있습니다. 기본적으로 재진입 잠금 RLock은 데이터 일관성을 유지하는 데 사용됩니다. 이번에 Python을 다시 배우기 전에는 Python 3.6을 사용하고 있었습니다. 당시에는 mp 라이브러리에 대한 피상적인 지식을 사용했지만 다양한 운영 체제에서 다중 프로세스 프로그램의 다양한 동작과 그에 따른 영향을 깊이 고려하지 않았습니다.
이번 공부를 하다가 문제에 부딪혔습니다. macOS 시스템에서 Python 3.12를 사용하여 전역 컨텍스트에서 multiprocessing.sharedctypes.Value 변수를 생성할 때 새 프로세스에서 이 변수에 액세스하면 해당 값이 동기화되지 않습니다. 서로 다른 프로세스 간에 유지됩니다. Eric Greene 선생님과 논의한 결과 Python 3.8부터 다양한 운영 체제에서 새로운 프로세스를 생성하는 방법이 변경되었다는 사실을 발견했습니다.
- Linux 시스템은 항상 포크를 사용하여 새로운 프로세스를 생성합니다. 포크 중에는 상위 프로세스의 모든 리소스가 하위 프로세스에 상속되므로 상위 프로세스에 전역적으로 정의된 동기화 변수를 하위 프로세스에서도 액세스할 수 있으므로 데이터 일관성이 유지됩니다.
- Windows 시스템은 항상 멀티 프로세싱을 구현하기 위해 새로운 Python 인터프리터 프로세스를 생성하는 방법인 스폰(spawn)을 사용합니다. Python을 "더 많이 여는 것"과 동일하므로 오버헤드가 더 많고 효율성이 떨어지지만 이는 Windows 시스템 자체의 한계입니다. 이 경우 하위 프로세스 는 새 프로세스를 시작하기 위해 상위 프로세스 의 run() 메서드에 필요한 리소스만 상속합니다.
- Python 3.8 이전에는 macOS 시스템에서 포크를 사용한 후 스폰으로 변경하여 일부 다중 프로세스 동작이 변경되었습니다. (macOS는 여전히 포크를 사용하도록 설정할 수 있지만 Python은 공식적으로 권장되지 않습니다)
제 예에서는 동기화된 변수가 상위 프로세스에서 전역적으로 선언되기 때문에 Windows 및 macOS 시스템의 하위 프로세스에서 상속되지 않으므로 Linux 시스템의 프로세스마다 값이 다릅니다. , 상위 프로세스의 모든 리소스가 상속되므로 하위 프로세스가 해당 값을 변경할 수 있습니다.
이로 인해 내가 본 현상이 발생했습니다. macOS에서 내 코드의 전역 동기화 변수는 변경되지 않았지만 다른 사람의 Linux 시스템은 정상적으로 실행되었으며 변수는 모든 프로세스에서 동기화되었습니다.
참고자료:
- https://docs.python.org/3/library/multiprocessing.html#contexts-and-start-methods
- https://docs.python.org/3/library/multiprocessing.html#multiprocessing.sharedctypes.synchronized
위 내용은 다양한 운영 체제에서 동기화된 변수의 다양한 동작의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

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

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

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

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

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

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

뜨거운 주제











Fiddlerevery Where를 사용할 때 Man-in-the-Middle Reading에 Fiddlereverywhere를 사용할 때 감지되는 방법 ...

Linux 터미널에서 Python 사용 ...

10 시간 이내에 컴퓨터 초보자 프로그래밍 기본 사항을 가르치는 방법은 무엇입니까? 컴퓨터 초보자에게 프로그래밍 지식을 가르치는 데 10 시간 밖에 걸리지 않는다면 무엇을 가르치기로 선택 하시겠습니까?

Pythonasyncio에 대해 ...

Investing.com의 크롤링 전략 이해 많은 사람들이 종종 Investing.com (https://cn.investing.com/news/latest-news)에서 뉴스 데이터를 크롤링하려고합니다.

Python 3.6에 피클 파일 로딩 3.6 환경 오류 : ModulenotFounderRor : nomodulename ...

SCAPY 크롤러를 사용할 때 파이프 라인 파일을 작성할 수없는 이유에 대한 논의 지속적인 데이터 저장을 위해 SCAPY 크롤러를 사용할 때 파이프 라인 파일이 발생할 수 있습니다 ...
