Java进阶(10) - 网络编程

BIO、NIO、AIO
NIO vs IO之间的理念上面的区别(NIO将阻塞交给了后台线程执行)git

  • IO是面向流的,NIO是面向缓冲区的
    • Java IO面向流意味着每次从流中读一个或多个字节,直至读取全部字节,它们没有被缓存在任何地方;
    • NIO则能先后移动流中的数据,由于是面向缓冲区的
  • IO流是阻塞的,NIO流是不阻塞的
    • Java IO的各类流是阻塞的。这意味着,当一个线程调用read() 或 write()时,该线程被阻塞,直到有一些数据被读取,或数据彻底写入。该线程在此期间不能再干任何事情了
    • Java NIO的非阻塞模式,使一个线程从某通道发送请求读取数据,可是它仅能获得目前可用的数据,若是目前没有数据可用时,就什么都不会获取。NIO可以让您只使用一个(或几个)单线程管理多个通道(网络链接或文件),但付出的代价是解析数据可能会比从一个阻塞流中读取数据更复杂。 
    • 非阻塞写也是如此。一个线程请求写入一些数据到某通道,但不须要等待它彻底写入,这个线程同时能够去作别的事情。
  • 选择器
    • Java NIO的选择器容许一个单独的线程来监视多个输入通道,你能够注册多个通道使用一个选择器,而后使用一个单独的线程来“选择”通道:这些通道里已经有能够处理的输入,或者选择已准备写入的通道。这种选择机制,使得一个单独的线程很容易来管理多个通道。 
      参考:http://www.javashuo.com/article/p-xooiahlk-a.html

NIO通讯框架有Mina、Netty、Grizzly
https://blog.csdn.net/wang_snake/article/details/79249972github

BIO、NIO、AIO区别
https://blog.csdn.net/guanghuichenshao/article/details/79375967编程

网络编程
https://h2pl.github.io/categories/后端/Java网络编程与NIO/page/2/后端

相关文章
相关标签/搜索