当前位置: 首页 > wzjs >正文

移动端网站如何做导出功能梧州房源信息网

移动端网站如何做导出功能,梧州房源信息网,网站建立的步骤,wordpress生成站点地图一、NIO简介 Java NIO是Java1.4引入的一种新的IO API,它提供了非阻塞式IO,选择器、通道、缓冲区等新的概念和机制。相比传统的IO,多出的N不单纯是新的,更表现在Non-blocking非阻塞,NIO具有更高的并发性、可扩展性以及…

一、NIO简介

Java NIO是Java1.4引入的一种新的IO API,它提供了非阻塞式IO,选择器、通道、缓冲区等新的概念和机制。相比传统的IO,多出的N不单纯是新的,更表现在Non-blocking非阻塞,NIO具有更高的并发性、可扩展性以及消耗资源少的优点。

二、NIO与传统的BIO

NIO:同步非阻塞的,服务器实现模式为1一个线程处理多个连接。服务端只会创建一个线程负责管理Selector(多路复用器),Selector不断的轮询注册在其上的Channel(通道)中的IO事件,并将监听到的事件进行处理。

BIO:全称是Blocking IO,同步阻塞式IO,是JDK1.4之前的传统IO模型,服务器实现模式为一个连接一个线程,每当客户端有连接请求时服务端都会创建一个新的线程。

两者主要区别:

阻塞与非阻塞:

BIO是阻塞I/O模型,当线程执行读或写操作时,如果数据没有准备好,线程会一直阻塞,直到数据准备好或操作完成。这种模型在处理大量并发连接时,性能较差,因为每个连接都需要一个独立的线程来处理。

NIO是非阻塞I/O模型,线程在执行读或写操作时,如果数据没有准备好,线程不会阻塞,而是立即返回。线程可以继续处理其他任务,等到数据准备好时再进行处理。这种模型可以更高效地处理大量并发连接,因为一个线程可以同时处理多个连接。

同步与异步:

BIO是同步I/O模型,线程在执行I/O操作时,必须等待操作完成才能继续执行后续任务。这种模型在处理大量并发连接时,性能较差,因为每个连接都需要一个独立的线程来处理。

NIO是同步非阻塞I/O模型,线程在执行I/O操作时,不需要等待操作完成,可以继续执行其他任务。这种模型可以更高效地处理大量并发连接,因为一个线程可以同时处理多个连接。

缓冲区:

BIO使用流(Stream)进行数据传输,数据是直接从一个流传输到另一个流,没有缓冲区。这种模型在处理大量数据时,性能较差,因为每次传输的数据量较小。

NIO使用缓冲区(Buffer)进行数据传输,数据首先被写入缓冲区,然后再从缓冲区传输到目标。这种模型可以更高效地处理大量数据,因为可以一次性传输大量数据。

选择器:

BIO没有选择器(Selector)的概念,每个连接都需要一个独立的线程来处理。这种模型在处理大量并发连接时,性能较差,因为每个连接都需要一个独立的线程来处理。

NIO引入了选择器(Selector)的概念,一个线程可以通过选择器同时监控多个通道(Channel)的I/O事件。这种模型可以更高效地处理大量并发连接,因为一个线程可以同时处理多个连接。

三、NIO的工作流程

1.创建Selector

Selector是NIO的核心组件之一,用于监控多个Channel的状态。通过Selector.open()方法可以创建一个Selector实例。

Selector selector = Selector.open();

2.创建Channel并注册到Selector

Channel是NIO中用于数据传输的通道。常见的Channel类型包括SocketChannelServerSocketChannelFileChannel。创建Channel后,需要将其注册到Selector上,并指定感兴趣的事件类型(如OP_READOP_WRITEOP_CONNECTOP_ACCEPT)。

ServerSocketChannel serverChannel = ServerSocketChannel.open();
serverChannel.configureBlocking(false);
serverChannel.socket().bind(new InetSocketAddress(8080));
serverChannel.register(selector, SelectionKey.OP_ACCEPT);

3.轮询Selector

通过Selector.select()方法可以轮询已注册的Channel,检查是否有事件发生。该方法会阻塞,直到至少有一个Channel上的事件发生。

while (true) {int readyChannels = selector.select();if (readyChannels == 0) continue;Set<SelectionKey> selectedKeys = selector.selectedKeys();Iterator<SelectionKey> keyIterator = selectedKeys.iterator();while (keyIterator.hasNext()) {SelectionKey key = keyIterator.next();if (key.isAcceptable()) {// 处理连接事件} else if (key.isReadable()) {// 处理读事件} else if (key.isWritable()) {// 处理写事件}keyIterator.remove();}
}

4.处理事件

根据SelectionKey的事件类型,进行相应的处理。例如,如果是OP_ACCEPT事件,表示有新的客户端连接,可以调用ServerSocketChannel.accept()方法接受连接,并将新的SocketChannel注册到Selector上。

if (key.isAcceptable()) {ServerSocketChannel server = (ServerSocketChannel) key.channel();SocketChannel client = server.accept();client.configureBlocking(false);client.register(selector, SelectionKey.OP_READ);
}

5.读写数据

对于OP_READOP_WRITE事件,可以通过Buffer进行数据的读写操作。Buffer是NIO中用于存储数据的容器,常见的类型包括ByteBufferCharBuffer等。

if (key.isReadable()) {SocketChannel client = (SocketChannel) key.channel();ByteBuffer buffer = ByteBuffer.allocate(1024);int bytesRead = client.read(buffer);if (bytesRead > 0) {buffer.flip();byte[] data = new byte[buffer.limit()];buffer.get(data);System.out.println(new String(data));}
}

6.关闭资源

在处理完所有事件后,需要关闭ChannelSelector,释放系统资源。

serverChannel.close();
selector.close();

总结

NIO的工作流程主要包括创建Selector、注册Channel、轮询事件、处理事件以及读写数据。通过非阻塞的方式,NIO能够高效地处理大量并发连接,适用于高并发的网络应用场景。

四、NIO核心组件

Java NIO的核心组件包括ChannelBufferSelector等。

Channel

Channel是NIO中用于数据传输的通道,类似于传统I/O中的流,但支持双向数据传输。常见的Channel实现类包括:

  • FileChannel:用于文件读写。
  • SocketChannel:用于TCP网络通信。
  • ServerSocketChannel:用于监听TCP连接。
  • DatagramChannel:用于UDP网络通信。
SocketChannel socketChannel = SocketChannel.open();
socketChannel.connect(new InetSocketAddress("example.com", 80));
Buffer

Buffer是NIO中用于存储数据的容器,支持读写操作。常见的Buffer实现类包括:

  • ByteBuffer:存储字节数据。
  • CharBuffer:存储字符数据。
  • IntBuffer:存储整数数据。
  • FloatBuffer:存储浮点数数据。
ByteBuffer buffer = ByteBuffer.allocate(1024);
buffer.put("Hello, World!".getBytes());
buffer.flip();
while (buffer.hasRemaining()) {System.out.print((char) buffer.get());
}
Selector

Selector是NIO中用于多路复用的组件,允许单线程处理多个Channel。通过Selector,可以监控多个Channel的I/O事件(如连接、读、写等),并在事件发生时进行处理。

Selector selector = Selector.open();
SocketChannel channel = SocketChannel.open();
channel.configureBlocking(false);
channel.register(selector, SelectionKey.OP_READ);
while (true) {int readyChannels = selector.select();if (readyChannels == 0) continue;Set<SelectionKey> selectedKeys = selector.selectedKeys();Iterator<SelectionKey> keyIterator = selectedKeys.iterator();while (keyIterator.hasNext()) {SelectionKey key = keyIterator.next();if (key.isReadable()) {// 处理读事件}keyIterator.remove();}
}

如果我的内容对你有帮助,请点赞,评论,收藏。创作不易,大家的支持就是我坚持下去的动力!

 


文章转载自:

http://BwkS6NnO.bcngs.cn
http://6pSwpxx3.bcngs.cn
http://6shhB7ef.bcngs.cn
http://ShKgV2ZO.bcngs.cn
http://eWsxSzx8.bcngs.cn
http://iaV4N9rD.bcngs.cn
http://9z7gEqUc.bcngs.cn
http://qpUto2Wf.bcngs.cn
http://aY4hYe01.bcngs.cn
http://c5orQmgH.bcngs.cn
http://kvJ3lTOM.bcngs.cn
http://2rhUy3Ty.bcngs.cn
http://q2a282KI.bcngs.cn
http://kVgex1cr.bcngs.cn
http://x2Fz58hA.bcngs.cn
http://Y6UR4K7z.bcngs.cn
http://1eAGpjMm.bcngs.cn
http://f4aR7Sdm.bcngs.cn
http://ePfgetby.bcngs.cn
http://BeI66maj.bcngs.cn
http://Xx57kKbw.bcngs.cn
http://oFKCvMO1.bcngs.cn
http://okAanou0.bcngs.cn
http://9yuEzBIK.bcngs.cn
http://6xlNE8t9.bcngs.cn
http://KkGtSk4m.bcngs.cn
http://IDYRkh0A.bcngs.cn
http://RddFPeIW.bcngs.cn
http://JRQpfeEm.bcngs.cn
http://XLSCmFdo.bcngs.cn
http://www.dtcms.com/wzjs/648030.html

相关文章:

  • 网站建设服务器是什么软件应用
  • 创建个人主页网站设计模式
  • 免费淘宝客网站模板下载设计外贸网站
  • 百度云虚拟主机如何建设网站安福网站制作
  • 建立网站需要哪几个怎么搭建自己的网站卖货
  • 黑龙江省建设教育信息网站广州网站建设好公司
  • 网站开发语言 排行榜瑞安网站建设电话
  • 怀来县建设局网站室内设计师收入高吗
  • 单页导航网站模板wordpress自动标签插件
  • 哪个网站有代做课设的网站怎么找回密码
  • 网站建设网站搭建公众号同步到dede网站
  • 阿里云建站和华为云建站兰州app定制开发
  • 网站设计步骤图佛山定制网站建设
  • 松江新城建设集团有限公司网站河南建设监理协会官方网站
  • 家具网站设计网站wordpress 教育
  • 建设银行广西分行招聘网站个人电子商务网站建设方案
  • 我的世界建筑网站深圳营销型网站公司
  • 网站建设案例图片村网通为每个农村建设了网站
  • 工作准备区域的组成包括企业网站seo怎么做
  • 玉溪定制网站建设网页设计这个行业怎么样
  • 500亿网站建设免费软件库下载
  • 广西城乡建设名网站门窗 东莞网站建设
  • 主流网站开发技术框架美文网站源码
  • 阿尔山网站建设文化建设素材
  • 可以免费做3dLOGO的网站网络小说写作网站
  • 广州网站建设乐云seo模板中心江苏网站建设要多少钱
  • 无法进行网站备案百度站长平台链接提交
  • 江门网站推广想做网站选什么专业
  • 金科科技 做网站logo字体设计在线生成
  • 红酒 公司 网站建设手机网站页面尺寸大小