>  기사  >  Java  >  Java의 NIO와 IO 비교에 대한 자세한 소개

Java의 NIO와 IO 비교에 대한 자세한 소개

黄舟
黄舟원래의
2017-03-17 10:05:321197검색

이 글은 주로 Java의 NIO와 IO에 대한 자세한 설명과 비교를 소개하고 있으니 필요하신 분들은 참고하시면 됩니다.

Java의 NIO와 IO의 차이점

NIO는 JDK1.4에 도입된 비동기식 IO입니다. NIO의 핵심 부분은

  • 채널

  • 버퍼

  • 선택기


NIO와 IO 비교

일반적으로 NIO와 IO의 차이점 세 가지 측면에서:

  1. IO는 스트림 기반(Stream 지향)인 반면 NIO는 Buffer 기반(Buffer 지향)

  2. IO 작업 이고 NIO 작업은 비차단입니다

  3. IO에는 선택기 개념이 없지만 NIO에는 선택기 개념이 있습니다.


스트림 기반 버퍼 기반 기존 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.