이 글은 주로 Java의 NIO와 IO에 대한 자세한 설명과 비교를 소개하고 있으니 필요하신 분들은 참고하시면 됩니다.
Java의 NIO와 IO의 차이점
NIO는 JDK1.4에 도입된 비동기식 IO입니다. NIO의 핵심 부분은
채널
버퍼
NIO와 IO 비교
일반적으로 NIO와 IO의 차이점 세 가지 측면에서:스트림 기반 버퍼 기반 기존 IO
는 바이트 스트림이나 문자 스트림을 지향하지만 NIO에서는 기존 IO 스트림을 버리고 채널과 버퍼의 개념을 도입했습니다. NIO에서는 채널의 데이터를 버퍼로 읽거나 버퍼의 데이터를 채널에 쓸 수만 있습니다. 그럼 스트림 기반이란 무엇입니까? 일반적인 Java IO 작업에서는 스트리밍 방식으로 스트림에서 하나 이상의 바이트를 순차적으로 읽으므로 읽기 데이터를 마음대로 변경할 수 없습니다. .순차 작업인 IO와 달리 NIO에서는 원하는 위치에서 데이터를 읽을 수 있습니다.
차단 및 비차단
Java에서 제공하는 다양한 Stream 작업은 차단입니다. 그런 다음 읽기 작업이 완료될 때까지 read를 호출하는 스레드가 차단됩니다. NIO의 비차단 모드를 사용하면 IO 작업을 비차단적으로 수행할 수 있습니다. 예를 들어, NIO의 비차단 모드에서 read 메소드를 호출하면 이때 데이터가 있으면 read가 읽고, 이때 데이터가 없으면 read가 반환됩니다. 직접 현재 스레드를 차단하지 않습니다.선택기
선택기는 NIO 고유의 개념으로, Java NIO가 비차단 방식으로 IO 작업을 수행할 수 있는 핵심입니다.Selector를 통해 스레드는 여러 채널의 IO 이벤트를 모니터링할 수 있습니다. Selector에 채널을 등록하면 Selector의 내부 메커니즘이 등록된 채널을 사용할 수 있는지 자동으로 쿼리(선택)할 수 있습니다. 이벤트(예: 읽기 가능, 쓰기 가능, 네트워크 연결 완료 등) 이러한 선택기 메커니즘을 통해 하나의 스레드를 쉽게 사용하여 여러 채널을 효율적으로 관리할 수 있습니다.
위 내용은 Java의 NIO와 IO 비교에 대한 자세한 소개의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!