Python 프로 세 스 간 통신 의 이름 파 이 프 를 자세히 설명 합 니 다.
이름 파 이 프 는 전통 적 인 파이프 에 대한 확장 입 니 다.기본 파 이 프 는 익명 파이프 로 프로그램 이 실 행 될 때 만 존재 합 니 다.이름 이 붙 은 파 이 프 는 지속 적 이 며 필요 하지 않 을 때 삭제 해 야 합 니 다.
이름 파 이 프 는 파일 시스템 을 사용 하여 mkfifo()방법 으로 만 듭 니 다.만 들 면 두 개의 독립 된 프로 세 스 가 접근 할 수 있 습 니 다.하 나 는 읽 고 다른 하 나 는 쓸 수 있 습 니 다.
이름 파 이 프 는 읽 기와 쓰기 막 기 동작 을 지원 합 니 다.프로 세 스 가 파일 을 열 면 다른 프로 세 스 가 쓸 때 까지 막 힙 니 다.하지만 우 리 는 O 를 지정 할 수 있다.NONBLOCK 옵션 을 사용 하면 비 차단 모드 를 사용 합 니 다.
이름 파 이 프 는 읽 기 전용 또는 쓰기 전용 모드 로 열 어야 합 니 다.읽 기+쓰기 모드 로 열 수 없습니다.단 방향 으로 통신 하기 때 문 입 니 다.양 방향 통신 을 실현 하려 면 두 개의 이름 파 이 프 를 열 어야 한다.
다음은 Python 이 프로 세 스 간 통신 을 위해 이름 파 이 프 를 사용 하 는 예 입 니 다.
서버 엔 드
import os, time
read_path = "/tmp/pipe.in"
write_path = "/tmp/pipe.out"
if os.path.exists(read_path):
os.remove(read_path)
if os.path.exists(write_path):
os.remove(write_path)
os.mkfifo(write_path)
os.mkfifo(read_path)
rf = os.open(read_path, os.O_RDONLY)
wf = os.open(write_path, os.O_SYNC | os.O_CREAT | os.O_RDWR)
while True:
s = os.read(rf, 1024)
print "received msg: %s" % s
if len(s) == 0:
time.sleep(1)
continue
if "exit" in s:
break
os.write(wf, s)
os.close(rf)
os.close(wf)
클 라 이언 트 엔 드
import os
import time
write_path = "/tmp/pipe.in"
read_path = "/tmp/pipe.out"
wf = os.open(write_path, os.O_SYNC | os.O_CREAT | os.O_RDWR)
rf = None
for i in range(1, 11):
msg = "msg " + str(i)
len_send = os.write(wf, msg)
print "sent msg: %s" % msg
if rf is None:
rf = os.open(read_path, os.O_RDONLY)
s = os.read(rf, 1024)
if len(s) == 0:
break
print "received msg: %s" % s
time.sleep(1)
os.write(wf, 'exit')
os.close(rf)
os.close(wf)
테스트이상 이 바로 본 고의 모든 내용 입 니 다.여러분 의 학습 에 도움 이 되 고 저 희 를 많이 응원 해 주 셨 으 면 좋 겠 습 니 다.
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
Python의 None과 NULL의 차이점 상세 정보그래서 대상 = 속성 + 방법 (사실 방법도 하나의 속성, 데이터 속성과 구별되는 호출 가능한 속성 같은 속성과 방법을 가진 대상을 클래스, 즉 Classl로 분류할 수 있다.클래스는 하나의 청사진과 같아서 하나의 ...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.