Python에서 파일 읽기 및 쓰기를 캡슐화하기 위해 asyncio를 사용하는 방법에 대한 자세한 설명과 예
이 글에서는 주로 asyncio.Future 객체 를 사용하여 파일의 비동기 읽기 및 쓰기를 캡슐화하는 방법을 설명합니다. 도움이 필요한 친구들은
">
서문
을 참고하시면 됩니다. 네트워크 IO와 마찬가지로 파일을 읽고 쓰는 것도 번거로운 작업입니다. .
기본적으로 Python은 시스템의 차단 읽기 및 쓰기를 사용합니다. 이는
f = file('xx') f.read()
가 asyncio에서 호출되면 이벤트 루프가 차단된다는 의미입니다. 🎜>.
이 문서에서는 asyncio.Future 개체를 사용하여 파일의 비동기 읽기 및 쓰기를 캡슐화하는 방법을 간략하게 설명합니다. -blocking먼저 파일 읽기 및 쓰기를 비차단 형식으로 변경해야 합니다. 비차단의 경우 읽기에 대한 각 호출은 반환 값이 비어 있으면 즉시 반환됩니다. 그렇다면 파일 작업이 완료되지 않았다는 의미이고, 그렇지 않으면 파일 내용을 읽은 것입니다.차단과 비차단 간의 전환은 운영체제와 관련이 있으므로 이 글에서는 Linux 버전에 대해서만 씁니다. 일단 경험해 보면 Python의 동작이
flag = fcntl.fcntl(self.fd, fcntl.F_GETFL) if fcntl.fcntl(self.fd, fcntl.F_SETFL, flag | os.O_NONBLOCK) != 0: raise OSError()
. 자리 표시자이며 그 값은 미래에 계산됩니다.
result = wait future
를 사용하여 future가 값을 얻은 후 반환하고
future를 사용할 수 있습니다. .set_result(xxx).는 future 값을 설정할 수 있습니다. 즉, wait
연산자는 future.result()를 자동으로 호출하여 값을 가져옵니다. >
loop.call_soon 메서드를 통해함수
를 이벤트 루프에 삽입할 수 있습니다. 이 시점에서 비동기 파일 읽기 및 쓰기에 대한 아이디어가 드러납니다. 파일 읽기 및 쓰기가 완료되지 않은 경우 읽고 쓰기의 남은 바이트 수를 계산하고 읽기 및 쓰기가 완료될 때까지 이벤트 루프를 다시 삽입합니다.기존 Unix 프로그래밍에서는 비차단 파일 읽기 및 쓰기를 위한 while
루프가 asyncio 이벤트 루프로 대체되었습니다.위 내용은 Python에서 파일 읽기 및 쓰기를 캡슐화하기 위해 asyncio를 사용하는 방법에 대한 자세한 설명과 예의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

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

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

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

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

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

뜨거운 주제









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

이 기사에서는 HTML을 구문 분석하기 위해 파이썬 라이브러리 인 아름다운 수프를 사용하는 방법을 설명합니다. 데이터 추출, 다양한 HTML 구조 및 오류 처리 및 대안 (SEL과 같은 Find (), find_all (), select () 및 get_text ()와 같은 일반적인 방법을 자세히 설명합니다.

Python의 통계 모듈은 강력한 데이터 통계 분석 기능을 제공하여 생물 통계 및 비즈니스 분석과 같은 데이터의 전반적인 특성을 빠르게 이해할 수 있도록 도와줍니다. 데이터 포인트를 하나씩 보는 대신 평균 또는 분산과 같은 통계를보고 무시할 수있는 원래 데이터에서 트렌드와 기능을 발견하고 대형 데이터 세트를보다 쉽고 효과적으로 비교하십시오. 이 튜토리얼은 평균을 계산하고 데이터 세트의 분산 정도를 측정하는 방법을 설명합니다. 달리 명시되지 않는 한,이 모듈의 모든 함수는 단순히 평균을 합산하는 대신 평균 () 함수의 계산을 지원합니다. 부동 소수점 번호도 사용할 수 있습니다. 무작위로 가져옵니다 수입 통계 Fracti에서

이 기사는 딥 러닝을 위해 텐서 플로와 Pytorch를 비교합니다. 데이터 준비, 모델 구축, 교육, 평가 및 배포와 관련된 단계에 대해 자세히 설명합니다. 프레임 워크, 특히 계산 포도와 관련하여 주요 차이점

이 기사는 Numpy, Pandas, Matplotlib, Scikit-Learn, Tensorflow, Django, Flask 및 요청과 같은 인기있는 Python 라이브러리에 대해 설명하고 과학 컴퓨팅, 데이터 분석, 시각화, 기계 학습, 웹 개발 및 H에서의 사용에 대해 자세히 설명합니다.

이 기사는 Python 개발자가 CLIS (Command-Line Interfaces) 구축을 안내합니다. Typer, Click 및 Argparse와 같은 라이브러리를 사용하여 입력/출력 처리를 강조하고 CLI 유용성을 향상시키기 위해 사용자 친화적 인 디자인 패턴을 홍보하는 세부 정보.

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

이 기사는 프로젝트 종속성 관리 및 충돌을 피하는 데 중점을 둔 Python에서 가상 환경의 역할에 대해 설명합니다. 프로젝트 관리 개선 및 종속성 문제를 줄이는 데있어 생성, 활성화 및 이점을 자세히 설명합니다.
