为什么要写这本书

早在几年前,笔者就曾想过整理一份基于Java语言的NIO与Socket相关的稿件,因为市面上大部分的Java书籍都是以1章或2章的篇幅介绍NIO与Socket技术,并没有完整地覆盖该技术的知识点,而限于当时的时间及精力,- -直没有如愿。机会终于来了,公司要搭建基础构架知识体系,我负责公司该技术方向的培训,这重燃了我对NIO和Socket技术的热情。在学习Java技术的过程中,当学习了Java SE/Java EE之后想探索更深层次的技术,如大数据、分布式和高并发类等,可能会遇到针对NIO、Socket的学习,但NIO和Socket技术的学习并不像JDBC一样简单,学习NIO和Socket时可能要遇到很多的问题。为了在该技术领域有更高的追求,我将NIO和Socket的技术点以教案的方式进行了整理,并在公司中与同事一起进行学习和交流,同事的反响非常热烈。若干年前的心愿终于达成,同事们也很期待这本书能早日出版发行,那样他们就有真正的纸质参考资料了。希望本书能够受到其他学习NIO和Socket的读者喜爱,这是我最大的心愿。

本书介绍NIO和Socket开发中最值得关注的内容,并给出个人的一些想法和见解,希望拓宽读者的学习思路。

如何阅读本书

本着实用、易懂的学习原则,本书通过6章内容来介绍Java多线程相关的技术。

第1章缓冲区的使用

第1章介绍NIO技术中的缓冲区,包括Buffer、ByteBuffer、 CharBuffer 类的核心API的使用。

 

第2章通道和F ileChanne1类的使用

第2章介绍NIO技术中的Channel (通道)类的继承关系、核心接口的作用,并重点介绍FileChannel类的使用,以增加读者对NIO操作File类的熟悉度。

 

第3章获取网络设备信息

第3章介绍如何使用Networklnterface类获得网络接口的信息,包括IP地址、子网掩码等,还会介绍InetAddress和InterfaceAddress类的常见API。如果进行Java开发,且基于Socket技术,那么这章可以给你需要的信息。

 

第4章实现Socket通信

第4章介绍如何使用Java语言实现Socket通信。Socket通信是基于TCP/IP和UDP实现的。另外,将介绍ServerSocket、Socket、DatagramSocket 和DatagramPacket类的全部API。只有熟练掌握Socket技术后,在阅读相关网络框架的源代码时才不会迷茫。也就是说,如果读者想要进行Java高性能后台处理,那么必须要学习Socket,并且它是进行细化学习的基础。

 

 

 

第5章选择器的使用

第5章介绍NIO技术中最重要的Selector(选择器)技术。NIO技术的核心一多路复用就是在此章体现的。学习这章内容需要有Socket 的编程基础,这就是为什么在前面用两章篇幅来介绍Java的Socket 编程的原因。同步非阻塞可以大幅度提升程序运行的效率,就在此章体会- - 下吧。

 

第6章AI0的使用

第6章介绍AIO。AIO是异步I0, NIO是非阻塞I0。AIO 在NIO的基础上实现了异步执行、回调处理等高级功能,可以在不同的场景使用AIO或NIO,可以说NIO和AIO是Java高级程序员、架构师等必须要掌握的技术。为什么要写这本书

 

 

 

 

 

在本书写作的过程中,做到言简意赅,并且全部用演示案例的方式来讲解技术知识点,使读者看到代码及运行结果后就可以知道此项目要解决的是什么问题。这类似于网络中的博客风格,让读者用最短的时间学习知识点,明白知识点的应用方式及使用时的注意事项,取得快速学习并解决相应问题的效果。需要获取这份PDF的小伙伴可以转发+关注后私信(学习)免费获取到!

适读者对象

  1. Java程序员
  2. 系统架构师
  3. 大数据开发者
  4. 其他对NIO和Socket技术感兴趣的人员