栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

netty-阻塞模式,非阻塞模式

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

netty-阻塞模式,非阻塞模式

以下方法为阻塞模式(单线程)
只能干一件事。

import lombok.extern.slf4j.Slf4j;

import java.io.IOException;
import java.net.InetSocketAddress;
import java.nio.ByteBuffer;
import java.nio.channels.ServerSocketChannel;
import java.nio.channels.SocketChannel;
import java.util.ArrayList;
import java.util.List;

import static com.netty.c1.ByteBufferUtil.debugRead;

@Slf4j(topic = "c.Server")
public class Server {
    public static void main(String[] args) throws IOException {

        ByteBuffer buffer = ByteBuffer.allocate(16);

        // 创建服务器
        ServerSocketChannel ssc = ServerSocketChannel.open();

        // 绑定监听端口
        ssc.bind(new InetSocketAddress(8080));

        List channels = new ArrayList<>();
        while(true) {
            log.debug("connection...");
            // 建立与客户端的连接
            SocketChannel sc = ssc.accept(); // 阻塞方法,线程停止运行
            log.debug("connected...{}",sc);
            channels.add(sc);
            // 接受客户端发送的数据
            for (SocketChannel channel : channels) {
                log.debug("before read...{}",channel);
                channel.read(buffer); // 阻塞方法,线程停止运行
                buffer.flip();
                debugRead(buffer);
                buffer.clear();
                log.debug("after read...{}",channel);
            }
        }
    }
}

以下方法为非阻塞模式(单线程)

import lombok.extern.slf4j.Slf4j;

import java.io.IOException;
import java.net.InetSocketAddress;
import java.nio.ByteBuffer;
import java.nio.channels.ServerSocketChannel;
import java.nio.channels.SocketChannel;
import java.util.ArrayList;
import java.util.List;

import static com.netty.c1.ByteBufferUtil.debugRead;

@Slf4j(topic = "c.Server")
public class Server {
    public static void main(String[] args) throws IOException {

        ByteBuffer buffer = ByteBuffer.allocate(16);

        // 创建服务器
        ServerSocketChannel ssc = ServerSocketChannel.open();
        // 非阻塞模式
        ssc.configureBlocking(false);
        // 绑定监听端口
        ssc.bind(new InetSocketAddress(8080));

        List channels = new ArrayList<>();

        // 有一个缺点:没有连接请求时,也会不断循环。
        // 没有数据可读时,也会不断循环。
        while(true) {
            //log.debug("connection...");
            // 建立与客户端的连接
            SocketChannel sc = ssc.accept(); // 非阻塞,线程还会继续运行。如果没有建立连接,sc是null
            if(sc != null){
                log.debug("connected...{}",sc);
                sc.configureBlocking(false);
                channels.add(sc);
            }
            // 接受客户端发送的数据
            for (SocketChannel channel : channels) {
                //log.debug("before read...{}",channel);
                int read = channel.read(buffer); // 非阻塞,线程仍然继续运行。如果没有读到数据,read返回0
                if(read > 0) {
                    buffer.flip();
                    debugRead(buffer);
                    buffer.clear();
                    log.debug("after read...{}", channel);
                }
            }
        }
    }
}
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/726658.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号