메서드를 호출할 필요도 없고 파싱 오류가 있을 때 이를 빨리 발견할 수 있어 더 효율적인 코드
가 됩니다.
stream
을 통한 트랜잭션 파싱 코드는 다음과 같습니다.
classTx:
...
@classmethod
defparse(cls, stream):
serialized_version = stream.read(4)
➊
...
➊
stream
.
read
메서드로 현재 스트림 버퍼에 있는
4
바이트를 읽어와 파싱을 시작합니다.
즉 필요한
4
바이트만 읽어오기 때문에 직렬화된 트랜잭션 전체가 모일 때까지 기다리지
않습니다.
네트워크의 소켓 통신이나 파일 입출력에서 전체를 다 얻기 위해서는 어느 정도 전송 시간이
필요합니다. 반면, 파싱은 진행하면서 조금씩 데이터를 소모합니다. 따라서 파싱 입력으로 스
트림을 사용하면 데이터를 받는 순간마다 ...
Become an O’Reilly member and get unlimited access to this title plus top books and audiobooks from O’Reilly and nearly 200 top publishers, thousands of courses curated by job role, 150+ live events each month, and much more.