socket通道
服务端:
1.打开通道,绑定端口
2.监听请求
3.接收并处理请求:
①从客户端通道读取缓冲区的数据
②处理数据得到结果
③把结果写入客户端通道的缓冲区
4.关闭通道
注意:Buffer在nio中的主要作用就是与channel交互。但这几种类型中能与channel交互的只有ByteBuffer(坑爹的吧!)所以在用其他类型Buffer的时候,一般都是先将ByteBuffer转化为想用的类型,用的是byteBuffer.asCharBuffer()、byteBuffer.asIntBuffer()等方法进行转换。这种方式用术语来讲,叫做“产生其他种类Buffer的视图”;意思就是底层是ByteBuffer,但看起来是其它种类的Buffer,可以用相应的方法,但是视图发生了读写,底层的ByteBuffer也会发生变化。
package NIO.Channel;
import java.io.IOException;
import java.net.InetSocketAddress;
import java.nio.ByteBuffer;
import java.nio.IntBuffer;
import java.nio.channels.ServerSocketChannel;
import java.nio.channels.SocketChannel;
public class NioChannelServer {
private ByteBuffer buff = ByteBuffer.allocate(1024);
private IntBuffer intBuff = buff.asIntBuffer();
private Soc