知识大全 用Java实现多线程服务器程序
Posted 知
篇首语:男人无志,钝铁无钢,女人无志,乱草无秧。本文由小常识网(cha138.com)小编为大家整理,主要介绍了知识大全 用Java实现多线程服务器程序相关的知识,希望对你有一定的参考价值。
用Java实现多线程服务器程序 以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!
摘要 在Java出现之前 编写多线程程序是一件烦琐且伴随许多不安全因素的事情 利用Java 编写安全高效的多线程程序变得简单 而且利用多线程和Java的网络包我们可以方便的实现多线程服务器程序
Java是伴随Internet的大潮产生的 对网络及多线程具有内在的支持 具有网络时代编程语言的一切特点 从Java的当前应用看 Java主要用于在Internet或局域网上的网络编程 而且将Java作为主流的网络编程语言的趋势愈来愈明显 实际工作中 我们除了使用商品化的服务器软件外 时常需要按照实际环境编写自己的服务器软件 以完成特定任务或与特定客户端软件实现交互 在实现服务器程序时 为提高程序运行效率 降低用户等待时间 我们应用了在Java Applet中常见的多线程技术
一 Java中的服务器程序与多线程
在Java之前 没有一种主流编程语言能够提供对高级网络编程的固有支持 在其他语言环境中 实现网络程序往往需要深入依赖于操作平台的网络API的技术中去 而Java提供了对网络支持的无平台相关性的完整软件包 使程序员没有必要为系统网络支持的细节而烦恼
Java软件包内在支持的网络协议为TCP/IP 也是当今最流行的广域网/局域网协议 Java有关网络的类及接口定义在java net包中 客户端软件通常使用java 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的范围是 到 但 到 是标准Internet协议保留端口 而且在Unix主机上 这些端口只有root用户可以使用 一般自定义的端口号在 到 之间 仅初始化了ServerSocket还是远远不够的 它没有同客户机交互的套接字(Socket) 因此需要调用该类的accept方法接受客户呼叫 Accept()方法直到有连接请求才返回通信套接字(Socket)的实例 通过这个实例的输入 输出流 服务器可以接收用户指令 并将相应结果回应客户机 ServerSocket类的getInetAddress和getLocalPort方法可得到该服务器的IP地址和端口 setSoTimeout和getSoTimeout方法分别是设置和得到服务器超时设置 如果服务器在timout设定时间内还未得到accept方法返回的套接字实例 则抛出IOException的异常 Java的多线程可谓是Java编程的精华之一 运用得当可以极大地改善程序的响应时间 提高程序的并行性 在服务器程序中 由于往往要接收不同客户机的同时请求或命令 因此可以对每个客户机的请求生成一个命令处理线程 同时对各用户的指令作出反应 在一些较复杂的系统中 我们还可以为每个数据库查询指令生成单独的线程 并行对数据库进行操作 实践证明 采用多线程设计可以很好的改善系统的响应 并保证用户指令执行的独立性 由于Java本身是 线程安全 的 因此有一条编程原则是能够独立在一个线程中完成的操作就应该开辟一个新的线程
Java中实现线程的方式有两种 一是生成Thread类的子类 并定义该子类自己的run方法 线程的操作在方法run中实现 但我们定义的类一般是其他类的子类 而Java又不允许多重继承 因此第二种实现线程的方法是实现Runnable接口 通过覆蓋Runnable接口中的run方法实现该线程的功能 本文例子采用第一种方法实现线程
二 多线程服务器程序举例
以下是我们在项目中采用的多线程服务器程序的架构 可以在此基础上对命令进行扩充 本例未涉及数据库 如果在线程运行中需要根据用户指令对数据库进行更新操作 则应注意线程间的同步问题 使同一更新方法一次只能由一个线程调用 这里我们有两个类 receiveServer包含启动代码(main()) 并初始化ServerSocket的实例 在accept方法返回用户请求后 将返回的套接字(Socket)交给生成的线程类serverThread的实例 直到该用户结束连接
file://类receiveServer import java io *; import java util *; import java net *; public class receiveServer final int RECEIVE_PORT= ; file://该服务器的端口号 file://receiveServer的构造器 public receiveServer() ServerSocket rServer=null; file://ServerSocket的实例 Socket request=null; file://用户请求的套接字 Thread receiveThread=null; try rServer=new ServerSocket(RECEIVE_PORT); file://初始化ServerSocket System out println( Wele to the server! ); System out println(new Date()); System out println( The server is ready! ); System out println( Port: +RECEIVE_PORT); while(true) file://等待用户请求 request=rServer accept(); file://接收客户机连接请求 receiveThread=new serverThread(request); file://生成serverThread的实例 receiveThread start(); file://启动serverThread线程 catch(IOException e) System out println(e getMessage()); public static void main(String args[]) new receiveServer(); file://end of main file://end of class file://类serverThread import java io *; import java net *;
class serverThread extends Thread Socket clientRequest; file://用户连接的通信套接字 BufferedReader input; file://输入流 PrintWriter output; file://输出流 public serverThread(Socket s) file://serverThread的构造器 this clientRequest=s; file://接收receiveServer传来的套接字 InputStreamReader reader; OutputStreamWriter writer; try file://初始化输入 输出流 reader=new InputStreamReader(clientRequest getInputStream()); writer=new OutputStreamWriter(clientRequest getOutputStream()); input=new BufferedReader(reader); output=new PrintWriter(writer true); catch(IOException e) System out println(e getMessage()); output println( Wele to the server! ); file://客户机连接欢迎词 output println( Now is: +new java util Date()+ + Port: +clientRequest getLocalPort()); output println( What can I do for you? ); public void run() file://线程的执行方法 String mand=null; file://用户指令 String str=null; boolean done=false; while(!done) try str=input readLine(); file://接收客户机指令 catch(IOException e) System out println(e getMessage()); mand=str trim() toUpperCase(); if(str==null || mand equals( QUIT )) file://命令quit结束本次连接 done=true; else if(mand equals( HELP )) file://命令help查询本服务器可接受的命令 output println( query ); output println( quit ); output println( help ); else if(mand startsWith( QUERY )) file://命令query output println( OK to query something! ); //else if …… //在此可加入服务器的其他指令 else if(!mand startsWith( HELP ) && !mand startsWith( QUIT ) && !mand startsWith( QUERY )) output println( Command not Found! Please refer to the HELP! ); //end of while try clientRequest close(); file://关闭套接字 catch(IOException e) System out println(e getMessage()); mand=null; //end of run
cha138/Article/program/Java/gj/201311/27667相关参考
/** *authorannegu *date */ annegu做了一个简单的Http多线程的下载程序来讨论一下多线程并发下载以及断点续传的问题 这个程序的功能就是可以分多个线程从目标
知识大全 Java Socket 编程——多线程网络聊天程序
JavaSocket编程——多线程网络聊天程序 以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧! 用
虽然集成开发环境(IDE)可以为图形化应用程序提供很好的调试设置但是它不允许你调试多线程的Java服务器程序 幸运的是有几个工具可以做到例如日志应用程序接口(API)和Java调试器
集成开发环境(IDE)能给图形界面应用程序提供一个很好的调试工具但是它却不能调试一个多线程的Java服务器程序 幸运的是有几种工具例如logging应用程序接口(API)或者Java
Java多线程程序如何掌握基本语法 以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧! Java多线程
Java语言深入多线程程序模型研究 以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧! 多线程是较复杂
Java多线程进程应对同一程序运行资源 以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧! Java多
Java程序中的多线程 以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧! 一为什么会排队等待? 下
Java程序中的多线程(四) 以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧! 作者NeelVKum
Java程序中的多线程(二) 以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧! 作者NeelVKum