您的位置:首页 >> 编程开发 >> Java >> 线程 >> 正文
线程 RSS
 

Java实现多线程服务器程序

http://www.rdxx.com 01年11月16日 11:08 互联网 我要投稿

关键词: 多线程 , Java , 程序 , 服务器 , 服务 , 线程
在Java出现之前,编写多线程程序是一件烦琐且伴随许多不安全因素
的事情。利用Java,编写安全高效的多线程程序变得简单,而且利用多线程和Ja
va的网络包我们可以方便的实现多线程服务器程序。 

---- Java是伴随Internet的大潮产生的,对网络及多线程具有内在的支持,具有
网络时代编程语言的一切特点。从Java的当前应用看,Java主要用于在Internet
或局域网上的网络编程,而且将Java作为主流的网络编程语言的趋势愈来愈明显
。实际工作中,我们除了使用商品化的服务器软件外,时常需要按照实际环境编
写自己的服务器软件,以完成特定任务或与特定客户端软件实现交互。在实现服
务器程序时,为提高程序运行效率,降低用户等待时间,我们应用了在Java App
let中常见的多线程技术。 

---- 一、Java中的服务器程序与多线程 

---- 在Java之前,没有一种主流编程语言能够提供对高级网络编程的固有支持。
在其他语言环境中,实现网络程序往往需要深入依赖于操作平台的网络API的技术
中去,而Java提供了对网络支持的无平台相关性的完整软件包,使程序员没有必
要为系统网络支持的细节而烦恼。 

---- Java软件包内在支持的网络协议为TCP/IP,也是当今最流行的广域网/局域
网协议。Java有关网络的类及接口定义在java.net包中。客户端软件通常使用ja
va.net包中的核心类Socket与服务器的某个端口建立连接,而服务器程序不同于
客户机,它需要初始化一个端口进行监听,遇到连接呼叫,才与相应的客户机建
立连接。Java.net包的ServerSocket类包含了编写服务器系统所需的一切。下面
给出ServerSocket类的部分定义。 

public class ServerSocket {
public ServerSocket(int port)
 throws IOException ;
public Socket accept() throws IOException ;
public InetAddress getInetAddress() ;
public int getLocalPort() ;
public void close() throws IOException ;
public synchronized void setSoTimeout
(int timeout) throws SocketException ;
public synchronized int
 getSoTimeout() throws IOException ;
}


---- ServerSocket构造器是服务器程序运行的基础,它将参数port指定的端口初
始化作为该服务器的端口,监听客户机连接请求。Port的范围是0到65536,但0到
1023是标准Internet协议保留端口,而且在Unix主机上,这些端口只有root用户
可以使用。一般自定义的端口号在8000到16000之间。仅初始化了ServerSocket还
是远远不够的,它没有同客户机交互的套接字(Socket),因此需要调用该类的
accept方法接受客户呼叫。Accept()方法直到有连接请求才返回通信套接字(Soc
ket)的实例。通过这个实例的输入、输出流,服务器可以接收用户指令,并将相
应结果回应客户机。ServerSocket类的getInetAddress和getLocalPort方法可得
到该服务器的IP地址和端口。setSoTimeout和getSoTimeout方法分别是设置和得
到服务器超时设置,如果服务器在timout设定时间内还未得到accept方法返回的
套接字实例,则抛出IOException的异常。 
---- Java的多线程可谓是Java编程的精华之一,运用得当可以极大地改善程序的
响应时间,提高程序的并行性。在服务器程序中,由于往往要接收不同客户机的
同时请求或命令,因此可以对每个客户机的请求生成一个命令处理线程,同时对
各用户的指令作出反应。在一些较复杂的系统中,我们还可以为每个数据库查询
指令生成单独的线程,并行对数据库进行操作。实践证明,采用多线程设计可以
很好的改善系统的响应,并保证用户指令执行的独立性。由于Java本身是"线程安
上一页 下一页

 
 
标签: 多线程 , Java , 程序 , 服务器 , 服务 , 线程 打印本文
 
 
  热点搜索
 
 
 



Valid XHTML 1.0 Transitional
Copyright ©2005 - 2008 Rdxx.Com,All Rights Reserved
收藏本页
收藏本站