Python의 다중 처리에서는 대규모 데이터 구조가 공유되거나 복사됩니까?
멀티프로세싱의 공유 메모리
Python의 멀티프로세싱 모듈에서는 대규모 데이터 구조가 프로세스 간에 공유되거나 복사되는지 여부가 문제가 됩니다.
원래 고려 사항
multiprocessing.Process를 사용하여 여러 프로세스를 생성하고 큰 목록을 인수로 전달할 때 문제는 이러한 목록이 각 프로세스에 대해 복사되는지 아니면 서로 공유되는지입니다. 그들을. 각 프로세스에서 복사본을 만들면 메모리 사용량이 크게 늘어날 수 있습니다.
쓰기 시 복사
Linux는 쓰기 시 복사 방식을 사용합니다. 데이터는 수정될 때까지 물리적으로 복사되지 않습니다. 이는 각 하위 프로세스에 대해 목록이 중복되지 않음을 의미합니다.
참조 카운팅
그러나 객체에 액세스하면 참조 카운트가 업데이트됩니다. 하위 프로세스가 목록 요소에 액세스하면 참조 횟수가 늘어납니다. 결과적으로 전체 개체(목록)가 복사될지 여부가 불분명합니다.
메모리 사용량 모니터링
관찰 결과 전체 개체가 실제로 복사되는 것으로 나타났습니다. 참조 계산으로 인해 각 하위 프로세스마다 중복됩니다. 목록을 수정할 수 없고 참조 횟수가 항상 양수인 경우 문제가 됩니다.
Python 3.8.0의 공유 메모리
Python 3.8.0에서는 'true'를 도입합니다. multiprocessing.shared_memory 모듈을 사용하는 공유 메모리. 이를 통해 복사하지 않고도 여러 프로세스에서 액세스할 수 있는 공유 메모리 개체를 명시적으로 생성할 수 있습니다.
요약하면 Linux의 쓰기 중 복사 접근 방식은 대규모 데이터 구조를 복사할 가능성을 줄이지만 참조 카운팅은 실제 복사로 이어집니다. Python 3.8.0에서 '진정한' 공유 메모리를 사용하면 명시적으로 공유 객체를 생성하기 위한 메커니즘을 제공하여 이 문제를 해결합니다.
위 내용은 Python의 다중 처리에서는 대규모 데이터 구조가 공유되거나 복사됩니까?의 상세 내용입니다. 자세한 내용은 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)

뜨거운 주제











Linux 터미널에서 Python 버전을 보려고 할 때 Linux 터미널에서 Python 버전을 볼 때 권한 문제에 대한 솔루션 ... Python을 입력하십시오 ...

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

Python의 Pandas 라이브러리를 사용할 때는 구조가 다른 두 데이터 프레임 사이에서 전체 열을 복사하는 방법이 일반적인 문제입니다. 두 개의 dats가 있다고 가정 해

Uvicorn은 HTTP 요청을 어떻게 지속적으로 듣습니까? Uvicorn은 ASGI를 기반으로 한 가벼운 웹 서버입니다. 핵심 기능 중 하나는 HTTP 요청을 듣고 진행하는 것입니다 ...

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

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

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