`
JasonShieh
  • 浏览: 528486 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

Android开发进阶之NIO非阻塞包(四)

阅读更多
今天我们通过一个实例详细讲解下Android下NIO非阻塞服务器的开发,对于客户端而言Android123不推荐使用NIO,毕竟NIO相对于传统IO较为复杂,最重要的NIO是为了解决多线程并发问题而解决的技术,可能会因为管理和复杂性降低最终的结果,毕竟NIO是Java的,相关的类型比较难控制,对于客户端而言我们可以使用C++、Java、C#甚至Flash Action Script来编写。    下面我们以一个简单的Echo Server为例子来分析
import java.io.IOException;
import java.NET.InetSocketAddress;
import java.nio.ByteBuffer;
import java.nio.CharBuffer;
import java.nio.channels.SelectionKey;
import java.nio.channels.Selector;
import java.nio.channels.ServerSocketChannel;
import java.nio.channels.SocketChannel;
import java.nio.charset.Charset;
import java.nio.charset.CharsetDecoder;
import java.nio.charset.CharsetEncoder;
import java.util.Iterator;
public class Server {
public static void main(String[] args) {
  Selector selector = null;
  ServerSocketChannel ssc = null;
  try {
      selector = Selector.open(); //实例化selector
      ssc = ServerSocketChannel.open(); //实例化ServerSocketChannel 对象
      ssc.socket().bind(new InetSocketAddress(1987)); //绑定端口为1987
      ssc.configureBlocking(false); //设置为非阻塞模式
      ssc.register(selector, SelectionKey.OP_ACCEPT); //注册关心的事件,对于Server来说主要是accpet了

   while (true) {
   int n= selector.select(); //获取感兴趣的selector数量
   if(n<1)
          continue; //如果没有则一直轮训检查
    Iterator<SelectionKey> it = selector.selectedKeys().iterator(); //有新的链接,我们返回一个SelectionKey集合
    while (it.hasNext()) {
     SelectionKey key = it.next(); //使用迭代器遍历
     it.remove(); //删除迭代器
     if (key.isAcceptable()) { //如果是我们注册的OP_ACCEPT事件
      ServerSocketChannel ssc2 = (ServerSocketChannel) key.channel();
      SocketChannel channel = ssc2.accept();
      channel.configureBlocking(false); //同样是非阻塞
      channel.register(selector, SelectionKey.OP_READ); //本次注册的是read事件,即receive接受
      System.out.println("CWJ Client :" + channel.socket().getInetAddress().getHostName() + ":"  + channel.socket().getPort());
     }
    else if (key.isReadable()) { //如果为读事件
      SocketChannel channel = (SocketChannel) key.channel();
      ByteBuffer buffer = ByteBuffer.allocate(1024); //1KB的缓冲区
      channel.read(buffer); //读取到缓冲区
      buffer.flip(); //准备写入
      System.out.println("android123 receive info:" + buffer.toString());
      channel.write(CharBuffer.wrap("it works".getBytes())); //返回给客户端
     }
    }
   }
  } catch (IOException e) {
   e.printStackTrace();
  } finally {
   try {
    selector.close();
    server.close();
   } catch (IOException e) {
   }
  }
}
}
上面是比较简单的框架,里面存在很多问题,Android123将在下次详细阐述下,上面或者说国内有关NIO资料中的通病,如果你看过Mina或GlassFish的源码,你可能就知道上面的问题大于10种,有关框架的bug占了大多数,作为服务器而言很容易CPU超过100%
分享到:
评论

相关推荐

    Android开发进阶之NIO非阻塞包

    ### Android开发进阶之NIO非阻塞包 #### NIO非阻塞通讯方式解析 在探讨Android DDMS源码中的NIO(Non-blocking I/O)非阻塞通讯方式时,我们首先需要理解NIO的基本概念及其在Android开发中的应用。 **NIO简介**:...

    android开发进阶之NIO非阻塞包

    ### Android开发进阶之NIO非阻塞包 #### 关键知识点概述 1. **NIO(New I/O)的概念**:NIO是Java 1.4版本开始引入的新I/O处理模型,它通过非阻塞的方式提高了I/O操作的性能。在Android开发中,利用NIO可以显著...

    Android开发进阶之NIO非阻塞包[定义].pdf

    总的来说,Android开发中的NIO技术提供了高性能、非阻塞的网络通信解决方案,有效地解决了多线程管理和资源消耗的问题。它不仅简化了并发编程,也提升了Android应用程序在网络通信方面的效率。对于Android开发者来说...

    尚硅谷全套视频打包下载地址

    8. **Java NIO**:非阻塞I/O操作在Java中的实现与应用。 9. **Java Web基础**:涵盖前端脚本语言、框架等基础知识。 10. **JavaScript DOM视频**:了解网页元素的操作与控制。 11. **jQuery视频**:简化HTML文档遍历...

    Android 面试指导.pdf

    Java的IO系统分为传统IO和NIO(非阻塞IO)。RandomAccessFile允许随机访问文件,而NIO引入了通道和缓冲区,提高了数据传输效率。异常处理是程序健壮性的关键,Java的异常分为检查异常和运行时异常,理解异常的层次...

    Java开发技术大全

    I/O流处理和NIO(非阻塞I/O)对于读写文件和网络通信至关重要。线程与并发编程是Java的强项,涉及线程同步、死锁避免、并发工具类(如Semaphore、CountDownLatch)等内容。 再者,Java EE(企业版)是Java在服务器...

    Java语言程序设计-基础篇-进阶篇源码

    5. **IO/NIO**:Java的I/O系统升级到NIO(非阻塞I/O),Channel、Buffer和Selector的使用。 6. **网络编程**:Socket编程,实现客户端和服务端的通信。 7. **枚举与注解**:枚举类型的使用,注解的定义和应用,以及...

    JAVA学习路线图+就业面试宝典+android视频地址

    对于IO流,理解输入输出处理,文件操作,以及NIO(非阻塞I/O)的概念也是必要的。 进一步,深入研究Java的反射机制,它允许我们在运行时动态地获取类的信息并调用其方法。还要学习Java的泛型,它提供了类型安全的...

    Java语言程序设计进阶篇

    - **网络I/O**:阻塞I/O、非阻塞I/O、NIO(New I/O)等。 - **JVM内存管理**: - **堆和栈**:理解它们的区别及其在程序中的作用。 - **垃圾回收**:GC算法、堆内存分区(如Young区、Old区)等。 - **性能调优*...

    java精通+开发案例 经典经典总结

    3. NIO(New Input/Output):提供非阻塞I/O,适用于高性能网络通信,如SocketChannel、Selector和Buffer。 六、网络编程 1. Socket编程:通过ServerSocket和Socket实现客户端-服务器通信,理解TCP和UDP协议的区别...

    公司内部Java培训资料

    - **IO流与NIO**:文件操作,网络通信,以及非阻塞I/O模型。 - **多线程**:线程同步、死锁避免以及并发工具类的使用。 - **集合框架**:ArrayList、LinkedList、HashMap等数据结构的使用和实现原理。 - **反射...

    java语言教程(001).rar

    学习者还需要熟悉集合框架,如ArrayList、LinkedList、HashMap等,以及IO流和NIO(非阻塞I/O)系统,这些用于数据的输入输出和文件操作。 在高级主题中,线程和并发处理是Java的一大亮点,理解如何创建和管理线程,...

    Java案例开发集锦

    7. **IO与NIO**:包括旧的I/O模型和新的非阻塞I/O模型,有助于优化读写操作。 8. **Java Swing和JavaFX**:介绍图形用户界面的构建,用于开发桌面应用。 9. **JDBC**:讲解如何连接数据库,执行SQL语句,处理结果...

    java学习线路

    * Java 高级知识:Annotation、IO 和 NIO、AIO、多线程、线程池、阻塞、非阻塞、异步网络通信、反射、动态代理 二、JDBC 编程 * SQL 基础:基础 SQL 语句、基本查询、多表查询、子查询、结果集的交、并、差运算 * ...

    SourceCodeReadProject:阅读JDK和Android SDK中的Java源代码以帮助学习-java project source code

    3. **I/O流**:`java.io`包提供了丰富的流处理类,通过源码我们可以学习如何进行数据的读写,了解缓冲流、字符流与字节流的区别,以及NIO(非阻塞I/O)的实现。 4. **集合框架**:Java集合框架是数据结构和算法的...

    jdk应用文当面

    - **NIO.2**:增加了文件系统操作的API,增强了非阻塞I/O能力。 - **Scripting API**:允许在Java应用程序中嵌入和使用脚本语言,如JavaScript。 - **Java Database Connectivity (JDBC) 4.0**:改进了数据库连接...

    尚硅谷xx视频直接下载

    进阶课程包括JUC并发编程、NIO非阻塞I/O等,帮助开发者提升性能优化能力。 JavaWeb阶段,尚硅谷提供JavaScript DOM编程、jQuery、Ajax等前端技术教程,以及JavaWeb核心技术和企业级项目实战,如Servlet、JSP、MVC...

    java 电子书教程

    8. **I/O与NIO**:Java I/O流用于读写文件和网络通信,而NIO(New IO)提供了一种非阻塞的I/O模型,提高了效率。 9. **Java Swing与JavaFX**:这些是Java的图形用户界面(GUI)工具包,用于创建桌面应用。 10. **...

Global site tag (gtag.js) - Google Analytics