首页 | 编程语言 | 网站建设 | 游戏天堂 | 冲浪宝典 | 网络安全 | 操作系统 | 软件时空 | 硬件指南 | 病毒相关 | IT 认证
软讯网络 > 编程语言 > Java > 一个非阻塞IO的java客户和服务器端交换时间的例子。
【标  题】:一个非阻塞IO的java客户和服务器端交换时间的例子。
【关键字】:IO,java
【来  源】:http://blog.csdn.net/ma_yan368/archive/2006/11/14/1383942.aspx

一个非阻塞IO的java客户和服务器端交换时间的例子。

import java.nio.ByteBuffer;
import java.nio.CharBuffer;
import java.nio.channels.ServerSocketChannel;
import java.nio.channels.SocketChannel;
import java.nio.channels.Selector;
import java.nio.channels.SelectionKey;
import java.nio.channels.SelectableChannel;
import java.nio.charset.Charset;
import java.nio.charset.CharsetDecoder;
import java.nio.charset.CharsetEncoder;

import java.net.InetAddress;
import java.net.Socket;
import java.net.ServerSocket;
import java.net.InetSocketAddress;
import java.util.*;
import java.util.Date;
import java.util.Iterator;

public class MyServer {
 SocketChannel sc;

 ServerSocketChannel ssc;

 Selector selector;

 private static Charset charset = Charset.forName("US-ASCII");

 private static CharsetEncoder encoder = charset.newEncoder();

 private static CharsetDecoder decoder = charset.newDecoder();

 ByteBuffer br = ByteBuffer.allocate(1024);

 MyServer() {
  try {
   InetSocketAddress addr = new InetSocketAddress(InetAddress
     .getLocalHost(), 26);

   ssc = ServerSocketChannel.open();
   ssc.configureBlocking(false);
   ServerSocket ss = ssc.socket();
   ss.bind(addr);
   System.out.println("asdf");
   selector = Selector.open();
   ssc.register(selector, SelectionKey.OP_ACCEPT);

   while (true) {
    if (selector.select() > 0) {
     System.out.println("asdf");
     Set readyKeys = selector.selectedKeys();
     Iterator it = readyKeys.iterator();
     while (it.hasNext()) {
      SelectionKey sk = (SelectionKey) it.next();
      it.remove();
      if (sk.isAcceptable()) {
       sc = ssc.accept();
       sc.read(br);
       br.flip();
       CharBuffer cb = decoder.decode(br);
       System.out.print(" : " + cb);
       sc.configureBlocking(false);
       sk=sc.register(selector,0);
       sk.interestOps(SelectionKey.OP_WRITE);
       System.out.println("isaccept()");
       //selector.wakeup();
       }
      if(sk.isReadable()){
       sc.read(br);
       br.flip();
       CharBuffer cb = decoder.decode(br);
       System.out.print("is readable  : " + cb);
       sk.interestOps(SelectionKey.OP_WRITE);
       System.out.println("set write");
       //selector.wakeup();
      }
      if(sk.isWritable()){
        String now = new Date().toString();
        sc.write(encoder.encode(CharBuffer.wrap("write"+now +
        "\r\n")));
        System.out.println(sc.socket().getInetAddress() +
        " : " + now);
        sk.interestOps(SelectionKey.OP_READ);
       // selector.wakeup();
       
      }
     }
    }
   }
  } catch (Exception e) {
   e.printStackTrace();
  } finally {
   try {
    sc.close();
    ssc.close();

   } catch (Exception e) {
   }
  }

 }

 public static void main(String args[]) {
  new MyServer();
 }

 

import java.nio.channels.SocketChannel;
import java.net.InetAddress;
import java.net.InetSocketAddress;
import java.nio.ByteBuffer;
import java.nio.CharBuffer;
import java.nio.channels.Selector;
import java.nio.channels.SelectionKey;
import java.util.*;
import java.util.Date;
import java.nio.charset.*;
import java.io.IOException;

public class MyClient {
 SocketChannel sc;

 Selector selector;

 private final int MAX_LENGTH = 1024;

 // private static Charset charset = Charset.forName("US-ASCII");

 private static Charset charset = Charset.forName("US-ASCII");

 private static CharsetDecoder decoder = charset.newDecoder();

 private static CharsetEncoder encoder = charset.newEncoder();

 private ByteBuffer r_buff = ByteBuffer.allocate(MAX_LENGTH);

 public MyClient() {
  try {
   InetSocketAddress addr = new InetSocketAddress(InetAddress
     .getLocalHost(), 26);

   sc = SocketChannel.open();
            sc.configureBlocking(false);
            sc.connect(addr);
   selector=Selector.open();
      sc.register(selector,SelectionKey.OP_CONNECT);
   System.out.println("register(selector, SelectionKey.OP_CONNECT");
   while (true) {
    int n=selector.select(30);
    //System.out.println("elector.select(30)="+n);
    if (n> 0) {
     Set set = selector.selectedKeys();
     Iterator it = set.iterator();
     while (it.hasNext()) {
      System.out.println("it.hasNext()");
      SelectionKey sk = (SelectionKey) it.next();
      it.remove();
      set.clear();
      if (sk.isConnectable()) {
       
       if(sc.isConnectionPending()){
        sc.finishConnect();
       }
       System.out.println("4");
       r_buff.clear();
       // sc.read(r_buff);
       String now = new Date().toString();
       sc.write(encoder.encode(CharBuffer.wrap(now
         + "\r\n")));

       // r_buff.flip();
       // CharBuffer cb = decoder.decode(r_buff);
       // System.out.print(" : " + cb);
       sc.register(selector,SelectionKey.OP_READ);
      }
      if(sk.isReadable()){
        sc.read(r_buff);
        r_buff.flip();
        CharBuffer cb = decoder.decode(r_buff);
        System.out.print(" : " + cb);
        sc.register(selector,SelectionKey.OP_WRITE);
      }
      if(sk.isWritable()){
       r_buff.clear();
       // sc.read(r_buff);
       String now = new Date().toString();
       sc.write(encoder.encode(CharBuffer.wrap(now
         + "\r\n")));

       // r_buff.flip();
       // CharBuffer cb = decoder.decode(r_buff);
       // System.out.print(" : " + cb);
       sc.register(selector,SelectionKey.OP_READ);
      }
     }
    }
   }
  } catch (IOException ioe) {
   ioe.printStackTrace();
  } finally {
   try {
    sc.close();
   } catch (IOException ioe) {
    System.err.println("finally sth. is wrong with br.readline() ");
   }
  }
 }

 public static void main(String args[]) {
  new MyClient();
 }
}
/*
public MyClient() {
  try {
   InetSocketAddress addr = new InetSocketAddress(InetAddress
     .getLocalHost(), 26);

   sc = SocketChannel.open();
            sc.configureBlocking(false);
            sc.connect(addr);
   if (sc.finishConnect()) {
    System.out.println("connection has been established!...");

   }
   
   r_buff.clear();
   // sc.read(r_buff);
   String now = new Date().toString();
   sc.write(encoder.encode(CharBuffer.wrap(now
     + "\r\n")));
   
   selector=Selector.open();
   SelectionKey skey = sc.register(selector,0 );
   skey.interestOps(SelectionKey.OP_CONNECT);
   System.out.println("register(selector, SelectionKey.OP_CONNECT");
   while (true) {
    System.out.println(selector.select());
    if (selector.select(50000) > 0) {
     System.out.println("selector.select(30) > 0");
     Set set = selector.selectedKeys();
     Iterator it = set.iterator();
     if (it.hasNext()) {
      System.out.println("it.hasNext()");
      SelectionKey sk = (SelectionKey) it.next();
      if (sk.isConnectable()) {
       System.out.println("4");
       r_buff.clear();
       // sc.read(r_buff);
        now = new Date().toString();
       sc.write(encoder.encode(CharBuffer.wrap(now
         + "\r\n")));

       // r_buff.flip();
       // CharBuffer cb = decoder.decode(r_buff);
       // System.out.print(" : " + cb);
       sc.register(selector,SelectionKey.OP_READ);
       selector.wakeup();
      }
     }
    }
   }
  } catch (IOException ioe) {
   System.err.println("sth. is wrong with br.readline() ");
  } finally {
   try {
    sc.close();
   } catch (IOException ioe) {
    System.err.println("finally sth. is wrong with br.readline() ");
   }
  }
 }
 */

JSF的第一课:【上一篇】
一个简单的状态机实现模型:【下一篇】
【相关文章】
  • As3.0与java 5语法对比
  • Java集合框架总结
  • 关于JAVA中参数传递问题的总结
  • C Primer Plus Fifth Edition 笔记chapter2
  • C Primer Plus. Fifth Edition 翻译Chapter 3 数据和C (Data and C)第一部分
  • Java,C#,C++在继承,覆盖和多态,抽象类等几个方面的比较归纳
  • [新闻] Sun releases Java as open-source project (GPL)
  • 深入Atlas系列:Web Sevices Access in Atlas示例(7) - 编写JavaScriptConverter处理含有循环引用的类型
  • ASP.NET Connections 大会的讲义和演示代码
  • sqlplus 调用带out参数的procedure&function
  • 【随机文章】
  • DOS程序员参考手册[1]
  • 安装完OpenBSD3.9时在分区要
  • 如何更简单的留你的webshell后门.
  • 建立动态的WML站点(一)
  • 我的研究笔记节选
  • SHELL的功能及分类
  • 针对SQL INJECTION的SQL SERVER安全设置初级篇
  • 提高网站在Google中的排名——面向搜索引擎的网站设计
  • eXutils.c
  • 简单Linux代码移植方法(ZT)
  • 【相关评论】
    没有相关评论
    【发表评论】
    姓名:
    邮件:
    随机码*
    评论*
          
    |  首 页  |  版权声明  |  联系我们   |  网站地图  |
    CopyRight © 2004-2007 软讯网络 All Rigths Reserved.