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

雄县网站建设wordpress守望

雄县网站建设,wordpress守望,网页上的视频怎么下载到电脑,网站右侧浮动导航优质博文:IT-BLOG-CN 一、阻塞IO / 非阻塞NIO 阻塞IO:当一条线程执行read()或者write()方法时,这条线程会一直阻塞直到读取到了一些数据或者要写出去的数据已经全部写出,在这期间这条线程不能做任何其他的事情。 非阻塞NIO&…

优质博文:IT-BLOG-CN

一、阻塞IO / 非阻塞NIO

阻塞IO:当一条线程执行read()或者write()方法时,这条线程会一直阻塞直到读取到了一些数据或者要写出去的数据已经全部写出,在这期间这条线程不能做任何其他的事情。

非阻塞NIONIO与原有的IO有同样的作用和目的,但是使用的方式完全不同,NIO支持面向缓冲区的、基于通道的操作。NIO将以更加高效的方式进行文件读写操作。JAVA NIO的核心在于:通道Channel和缓冲区Buffer。通道表示打开IO设备(例如:文件、套接字)的连接。若需要使用NIO系统,需要获取用于连接IO设备的通道以及用于容纳数据的缓冲区。对数据进行处理。

二、传统IO测试代码如下

当出现accept()read()等方法是就会阻塞。

/*** 传统socket服务端* @author -zhengzx-*/
public class OioServer {@SuppressWarnings("resource")public static void main(String[] args) throws Exception {//创建socket服务,监听10101端口ServerSocket server=new ServerSocket(10101);System.out.println("服务器启动!");while(true){//获取一个套接字(阻塞)final Socket socket = server.accept();//(测试时可以通过:telnet 127.0.0.1 10101。进行测试)System.out.println("来个一个新客户端!");//业务处理handler(socket);}}/*** 读取数据* @param socket* @throws Exception*/public static void handler(Socket socket){try {byte[] bytes = new byte[1024];InputStream inputStream = socket.getInputStream();while(true){//读取数据(阻塞)int read = inputStream.read(bytes);if(read != -1){System.out.println(new String(bytes, 0, read));}else{break;}}} catch (Exception e) {e.printStackTrace();}finally{try {System.out.println("socket关闭");socket.close();} catch (IOException e) {e.printStackTrace();}}}
}

三、阻塞 IO解决办法

可以通过线程池创建多线程,为每一次连接创建一个新的线程来执行。问题是对于长连接而言,线程过多时会严重消耗系统资源导致性能下降。比较适合短连接的应用。

public static void main(String[] args) throws Exception {//创建线程池(可以通过线程解决阻塞问题、问题:每次连接都会创建一个线程,特别是长连接时特别消耗系统资源)ExecutorService newCachedThreadPool = Executors.newCachedThreadPool();//创建socket服务,监听10101端口ServerSocket server=new ServerSocket(10101);System.out.println("服务器启动!");while(true){//获取一个套接字(阻塞)final Socket socket = server.accept();//(测试时可以通过:telnet 127.0.0.1 10101。进行测试)System.out.println("来个一个新客户端!");newCachedThreadPool.execute(new Runnable() {@Overridepublic void run() {//业务处理handler(socket);}});}
}

四、NIO 的非阻塞模式

Java NIO有阻塞模式和非阻塞模式,阻塞模式的NIO除了使用Buffer存储数据外和IO基本没有区别,允许一条线程从Channel中读取数据,通过返回值来判断buffer中是否有数据,如果没有数据,NIO不会阻塞,因为不阻塞这条线程就可以去做其他的事情,过一段时间再回来判断一下有没有数据。

*SelectorsJava NIOselectors允许一条线程去监控多个channels的输入,你可以向一个selector上注册多个channel,然后调用selectorselect()方法判断是否有新的连接进来或者已经在selector上注册时channel是否有数据进入。selector的机制让一个线程管理多个channel变得简单。

五、NIO示例代码如下

客户端使用SocketChannel,服务端使用ServerSocketChannel获取通道

public class NIOServerSocket {//定义一个socket入口private ServerSocketChannel serverSocket;//定义一个监听器Selector selector;public static void main(String[] args) throws IOException {NIOServerSocket nio =new NIOServerSocket();nio.initServer(8000);nio.listen();}public void initServer(int port) throws IOException {//获取一个serverSocket通道serverSocket = ServerSocketChannel.open();//设置为非阻塞状态(分为阻塞和非阻塞两种情况)serverSocket.configureBlocking(false);//将通道对应的serverSocketChannel绑定到端口上serverSocket.socket().bind(new InetSocketAddress(port));//获取一个通道管理器this.selector = Selector.open();//将通道管理器与通道进行绑定,并赋值SelectionKey.OP_ACCEPT事件//注册后,当事件到达后,select.select()会返回,如果没有返回,就一直阻塞。serverSocket.register(selector, SelectionKey.OP_ACCEPT);}public void listen() throws IOException {System.out.println("服务器启动");//轮询访问select.select()while(true) {//当事件到达时返回,否则一直阻塞Channel channel = selector.select();//获取selector中选中项的迭代器,相中的项为注册事件。Iterator<SelectionKey> iterator = this.selector.selectedKeys().iterator();while(iterator.hasNext()) {SelectionKey selectionKey = iterator.next();//删除已选的key,防止重复处理iterator.remove();handler(selectionKey);}}}public void handler(SelectionKey key) throws IOException {if(key.isAcceptable()) {handlerAccept(key);}else if(key.isReadable()) {handlerRead(key);}}public void handlerAccept(SelectionKey key) throws IOException {//获取以有的通道ServerSocketChannel channel = (ServerSocketChannel) key.channel();//获取和客户端连接的通道SocketChannel accept = channel.accept();//设置为非阻塞accept.configureBlocking(false);// 在这里可以给客户端发送信息哦System.out.println("新的客户端连接");//连接成功之后,为了读取客户端传送的消息,需要设置读权限accept.register(selector, SelectionKey.OP_READ);}public void handlerRead(SelectionKey key) throws IOException {//服务器可读取消息,获取事件发生的Socket通道SocketChannel channel = (SocketChannel) key.channel();//创建读取内容的缓存区bufferByteBuffer buffer = ByteBuffer.allocate(1024);int read = channel.read(buffer);if(read > 0) {byte[] array = buffer.array();String msg = new String(array).trim();System.out.println("服务端收到信息:" + msg);//会写ByteBuffer byteBuffer = ByteBuffer.wrap("success".getBytes());channel.write(byteBuffer);}else {System.out.println("客户端关闭");key.cancel();}}
}

六 、selector.select()

selector.select()虽阻塞,但可以通过selector.wakeup()唤醒selector执行,也可以通过selector.select(int timeout)设置时间限制,timeout时间后唤醒 selector

七、NIO提高性能

添加多线程,一个线程对应一个selector,端口的监听可以单独创建一个selector。(既Netty的工作原理)

总结: NIO允许你用一个单独的线程或几个线程管理很多个channels(网络的或者文件的),代价是程序的处理和处理IO相比更加复杂。如果你需要同时管理成千上万的连接,但是每个连接只发送少量数据,例如一个聊天服务器,用NIO实现会更好一些,相似的,如果你需要保持很多个到其他电脑的连接,例如P2P网络,用一个单独的线程来管理所有出口连接是比较合适的。

IO:如果你只有少量的连接但是每个连接都占有很高的带宽,同时发送很多数据,传统的IO会更适合

http://www.yayakq.cn/news/420646/

相关文章:

  • 手机网站上线左右滑动吴江区桃源镇做网站
  • 网站优化网站建站教程凡客诚品市场份额
  • 网站被挂马怎么处理7有免费建网站
  • 做网站表格单边框标记有的网站没设关键词
  • 怎么搭建一个视频网站建设网站的准备
  • 北京公司网站制作在58做网站推广有用没
  • 凡科建站代理商登录chn域名注册网站
  • 使用wordpress做图站手机推广app
  • 网站建设的原则 流程上海网站制作案例
  • 平面设计素材网站大全wordpress vip 插件
  • com网站是用什么做的安卓app开发环境
  • 网站集约化 建设方案单页网站建站
  • 建二手车网站企业建立自己的网站
  • 网站报价方案怎么做商丘做网站推广
  • 网站标题优化可以含几个关键词制作app定制开发公司
  • 网站可视化后台杭州平面设计培训
  • 内江市网站建设培训网站要做手机版怎么做的
  • 网站解析教程中国核工业二三建设有限公司太平岭项目部
  • 漯河网站建设(千弘网络)服务器安装完面板怎么做网站
  • 南京响应式网站制作百度指数什么意思
  • 网站做竞价需要什么信息舆情报告2023
  • 网站开发岗位群一天赚1000块钱的游戏
  • app应用网站单页模板现在建站好么
  • 简单网站开发准备杭州市下城区建设局门户网站
  • 廊坊哪里能够做网站博客推广工具
  • 自己有一个域名怎么做网站哪个公司建设网站
  • 网站备案登录小型装修公司店面装修
  • 如何建设网站兴田德润可信赖十大基本营销方式
  • 重庆制作网站的公司排名wordpress更改固定链接后
  • 东莞专业网站建设服务wordpress php版本要求