当前位置:  技术问答>java相关

如何用单线程实现和多个客户机通讯?

    来源: 互联网  发布时间:2015-10-05

    本文导语:  用java写的服务程序和客户端进行网络连接时,除了为每一个客户连接开一个线程来处理用户数据外,有没有什么方法能做到单路复用?也就是只用两三个线程来完成和多个客户机的连接,好像nio包提供了类似的功能...

用java写的服务程序和客户端进行网络连接时,除了为每一个客户连接开一个线程来处理用户数据外,有没有什么方法能做到单路复用?也就是只用两三个线程来完成和多个客户机的连接,好像nio包提供了类似的功能,但是不太会,谁能写一个简单的例子,谢了!

|
给你一个用NIO的例子:


import java.io.*;
import java.net.*;
import java.nio.*;
import java.nio.channels.*;
import java.util.*;

public class MultiplexingChatServer implements Runnable
{
private int port;
private Vector sockets = new Vector();
private Set closedSockets = new HashSet();

public MultiplexingChatServer( int port ) {
this.port = port;
Thread t = new Thread( this, "MultiplexingChatServer" );
t.start();
}

public void run() {
try {
ServerSocketChannel ssc = ServerSocketChannel.open();
ssc.configureBlocking( false );
ServerSocket ss = ssc.socket();
InetSocketAddress isa = new InetSocketAddress( port );
ss.bind( isa );
Selector selector = Selector.open();
ssc.register( selector, SelectionKey.OP_ACCEPT );
System.out.println( "Listening on port "+port );

ByteBuffer buffer = ByteBuffer.allocate( 4096 );
while (true) {
int numKeys = selector.select();

if (numKeys>0) {

Set skeys = selector.selectedKeys();

Iterator it = skeys.iterator();
while (it.hasNext()) {
SelectionKey rsk = (SelectionKey)it.next();
int rskOps = rsk.readyOps();
if ((rskOps & SelectionKey.OP_ACCEPT) == SelectionKey.OP_ACCEPT) {
Socket socket = ss.accept();
System.out.println( "Connection from "+socket );
sockets.addElement( socket );
SocketChannel sc = socket.getChannel();
sc.configureBlocking( false );
sc.register( selector, SelectionKey.OP_READ );
selector.selectedKeys().remove( rsk );
} else if ((rskOps & SelectionKey.OP_READ) == SelectionKey.OP_READ) {
SocketChannel ch = (SocketChannel)rsk.channel();
selector.selectedKeys().remove( rsk );
buffer.clear();
ch.read( buffer );
buffer.flip();
System.out.println( "Read "+buffer.limit()+ " bytes from "+ch.socket() );
if (buffer.limit()==0) {
System.out.println( "closing on 0 read" );
rsk.cancel();
Socket socket = ch.socket();
close( socket );
} else {
sendToAll( buffer );
}
}
}
removeClosedSockets();
}
}
} catch( IOException ie ) {
ie.printStackTrace();
}
}

// This method is identical to
// PollingChatServer.sendToAll()
private void sendToAll( ByteBuffer bb ) {
for (Enumeration e=sockets.elements(); e.hasMoreElements();) {
Socket socket = null;
try {
socket = (Socket)e.nextElement();
SocketChannel sc = socket.getChannel();
bb.rewind();
while (bb.remaining()>0) {
sc.write( bb );
}
} catch( IOException ie ) {
closedSockets.add( socket );
}
}
}

private void close( Socket socket ) {
closedSockets.add( socket );
}

// This method is identical to
// PollingChatServer.removeClosedSockets()
private void removeClosedSockets() {
for (Iterator it=closedSockets.iterator(); it.hasNext();) {
Socket socket = (Socket)it.next();
sockets.remove( socket );
System.out.println( "Removed "+socket );
}
closedSockets.clear();
}

static public void main( String args[] ) throws Exception {
int port = Integer.parseInt( args[0] );
new MultiplexingChatServer( port );
}

}

    
 
 

您可能感兴趣的文章:

  • 一个进程中的多个线程不会被调度到一台机器中的多个cup并行执行吗?
  • POSIX线程中多个线程可以共用一个属性吗?
  • 有什么方法使多个线程进入休眠,并唤醒其中一个??
  • 如果多个线程同时select同一个套接字会怎么样?可以这样吗?
  • 请问多个线程同时读写同一文件的操作是否安全?
  • 一个进程分离出多个线程后cpu时间分配问题
  • 如果父进程有多个线程,那么它的子进程也该拥有这些线程
  • LINUX下访问oracle时sleeping的线程过多,达到300多个,造成系统拥堵!
  • 求教 Linux多个线程 可不可以同时调用一个函数
  • 请大家讨论,来者有分,java中多个线程之间共享数据的方法都有哪些?
  • linux下面如何让线程等待多个事件?
  • 同多个线程通过同一个socket发送数据,操作系统底层会同步每个发送操作吗
  • 弱弱的问:关于多个线程(就10分了,多谢了)
  • 求助!!!多线程+多个epoll_wait问题
  • linux下一个进程下面有多个线程的栈切换的问题,望高人指点下。
  • 在多核CPU下,同一进程下的多个线程可以并行运行吗?
  • UNIX中多个线程同时捕捉信号,信号由那个线程捕捉到?
  • 在linux7.3下多个线程使用 pthread_cond_t 的一个小问题。
  • 调用同一个函数建立的多个线程,如何使用函数的数据?
  • 怎么循环建立多个线程
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • Java中多线程相关类Thread介绍
  • 一个进程创建了两个线程,如何使得当任何一个线程(比如线程a)结束时,同时也结束线程b,也就是使两个线程一起死掉,怎么办呢?
  • c#多线程更新窗口(winform)GUI的数据
  • java 线程,对当前线程(非主线程)调用sleep,为什么主线程(窗口)也没反应了
  • Windows和Linux下C++类成员方法作为线程函数方法介绍
  • 如何实现一个线程组内多线程的非同不执行,即一个线程执行完毕后再执行下一个线程???
  • c++的boost库多线程(Thread)编程(线程操作,互斥体mutex,条件变量)详解
  • 请问:进程创建的线程是怎样运行的啊,线程的处理函数运行完了,线程就退出了吗?
  • Linux下GCC内置原子操作函数(多线程资源访问)介绍
  • 关于线程的问题,什么样的线程不是active线程?
  • 请问Linux核心支持多线程吗?开发库有线程库吗?线程好用吗?(稳定?)
  • 请问,在一个进程中创建多线程时如何能避免不同的线程获得同一个线程标识
  • 我的一个多线程服务里, 总是有一个线程莫名其妙的变成僵尸线程。
  • 能否通过线程id控制线程的状态?或是观察到线程的状态?
  • 如何在一个线程中启动另外一个线程,然后本线程就退出?
  • 我要设置一个线程的优先级, 这个属性结构并没有线程的id,它怎么知道是设置哪个线程呢?
  • 请问在java多线程中,是只有run(){}内的代码运行在一个新线程下呢?还是这个类中的代码都运行在一个新线程下?
  • gcc链接的库,分不分单线程版本的和多线程版本的?
  • 内核栈~ 内核线程 ~用户线程 之间关系 问题
  • 子线程的数据如何返回给主线程?
  • 如果父线程死掉 那么子线程会不会死掉呢


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3