Netty(九) - ServerSocketChannel和SocketChannel

一、ServerSocketChannel

1)、ServerSocketChannel 在服务器端监听新的客户端 Socket 连接

2)、public abstract class ServerSocketChannel extends AbstractSelectableChannel implements NetworkChannel

3)、相关方法

方法 描述
public static ServerSocketChannel open() 得到一个 ServerSocketChannel 通道
public final ServerSocketChannel bind(SocketAddress local) 设置服务器端端口号
public final SelectableChannel configureBlocking(boolean block) 设置阻塞或非阻塞模式,设置false表示采用非阻塞模式
public abstract SocketChannel accept() 接受一个连接,返回代表这个连接的通道对象
public final SelectionKey register(Selector sel, int ops) 注册一个选择器并设置监听事件

二、SocketChannel

1)、SocketChannel,网络 IO 通道,具体负责读写操作。NIO 把缓冲区的数据写入通道或者把通道里的数据读到缓冲区

2)、public abstract class SocketChannel extends AbstractSelectableChannel
implements ByteChannel, ScatteringByteChannel, GatheringByteChannel, NetworkChannel

3)、相关方法

方法 描述
public static SocketChannel open() 得到一个 SocketChannel 通道
public final SelectableChannel configureBlocking(boolean block) 设置阻塞或非阻塞模式,设置false表示采用非阻塞模式
public abstract boolean connect(SocketAddress remote) 连接服务器
public abstract boolean finishConnect() 如果 connect 方法连接失败,接下来就要通过 finishConnect 方法完成连接操作
public abstract int write(ByteBuffer src) 往通道里写数据
public abstract int read(ByteBuffer dst) 从通道里读数据
public final SelectionKey register(Selector sel,int ops,Object att) 注册一个选择器并设置监听事件,最后一个参数可以设置共享数据
public final void close() 关闭通道

猜你喜欢

转载自blog.csdn.net/yangxshn/article/details/113726171