前言
Java 语言诞生之初就提供了Socket
套接字相关 API,用于支撑网络编程需求。早期的Socket
接口是同步阻塞式IO,性能并不是很高,在服务端编程这块一直处于劣势。直到 JDK1.4 发布,伴随而来的是新的 NIO 包以及其提供了 IO 复用模型下的API,极大提高了网络IO效率,很多服务器开始采用这种模型,处理能力也有了极大的提升。随着 JDK1.7 的发布,JDK 也提供了对异步IO的支持。理论上来说,异步IO 是效率最高的。但是由于 Java 主要都是服务端程序,大部分都运行在Linux 系统上,而 Linux 对 AIO 的支持较晚。因此现在采用异步 IO 的且有较大影响力的程序还不多。
Java的服务端编年史
鸿蒙时代:BIO
伴随着Java的发布,带来的是Socket
套接字API。这套API实现是的同步阻塞IO模型。下面首先来看个示例,如何使用这套API完成一个echo服务端程序
public class MainDemo
{
public static void main(String[] args) throws IOException, ExecutionException, InterruptedException
{
ServerSocket serverSocket = new ServerSocket();