Netty实战(一)Nett的概念及体系结构

本文介绍了Java网络编程的发展,从阻塞I/O到非阻塞I/O(NIO)的转变,强调了NIO中的选择器在处理并发连接中的优势。Netty作为Java的高性能网络框架,它简化了NIO的使用,并具有高吞吐量、低延迟、易用性、健壮性等特性。Netty基于事件驱动和异步模型,使用Channel和ChannelHandler等核心组件,使得网络编程更加高效和简洁。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

第一章 Java网络编程

最早期的 Java API(java.net)只支持由本地系统套接字库提供的所谓的阻塞函数,像下面的那样

        //创建一个新的 ServerSocket,用以监听指定端口上的连接请求
        ServerSocket serverSocket = new ServerSocket(portNumber);
        //对 accept()方法的调用将被阻塞,直到一个连接建立.随后返回一个新的 Socket 用于客户端和服务器之间的通信。该 ServerSocket 将继续监听传入的连接。
        Socket clientSocket = serverSocket.accept();
        //这些流对象都派生于该套接字的流对象
        BufferedReader in = new BufferedReader(new InputStreamReader(clientSocket.getInputStream()));//从一个字符输入流中读取文本
        PrintWriter out = new PrintWriter(clientSocket.getOutputStream(), true);//打印对象的格式化的表示到文本输出流
        String request, response;
        //处理循环开始
        while ((request = in.readLine()) != null) {
    //readLine()方法将会阻塞,直到一个由换行符或者回车符结尾的字符串被读取。
            if ("Done".equals(request)) {
    //如果客户端发送了“Done”,则退出处理循环
                break;
            }
            //请求被传递给服务器的处理方法
            response = processRequest(request);//客户端的请求已经被处理
            out
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

timi先生

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值