欢迎来到装配图网! | 帮助中心 装配图网zhuangpeitu.com!
装配图网
ImageVerifierCode 换一换
首页 装配图网 > 资源分类 > DOCX文档下载
 

多线程服务器程序

  • 资源ID:108687694       资源大小:13.96KB        全文页数:3页
  • 资源格式: DOCX        下载积分:10积分
快捷下载 游客一键下载
会员登录下载
微信登录下载
三方登录下载: 微信开放平台登录 支付宝登录   QQ登录   微博登录  
二维码
微信扫一扫登录
下载资源需要10积分
邮箱/手机:
温馨提示:
用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)
支付方式: 支付宝    微信支付   
验证码:   换一换

 
账号:
密码:
验证码:   换一换
  忘记密码?
    
友情提示
2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

多线程服务器程序

用Java实现多线程服务器程序摘要:在Java出现之前,编写多线程程序是一件烦琐且伴随许多不安全因素的事情。利用Java,编写安全高效的多线程程序变得简单,而且利用多线程和Java的网络包我们可以方便的实现多线程服务器程序。Java是伴随Internet的大潮产生的,对网络及多线程具有内在的支持,具有网络时代编程语言的一切特点。从Java的当前应用看,Java主要用于在Internet或局域网上的网络编程,而且将Java作为主流的网络编程语言的趋势愈来愈明显。实际工作中,我们除了使用商品化的服务器软件外,时常需要按照实际环境编写自己的服务器软件,以完成特定任务或与特定客户端软件实现交互。在实现服务器程序时,为提高程序运行效率,降低用户等待时间,我们应用了在JavaApplet中常见的多线程技术。一、Java中的服务器程序与多线程在Java之前,没有一种主流编程语言能够提供对高级网络编程的固有支持。在其他语言环境中,实现网络程序往往需要深入依赖于操作平台的网络API的技术中去,而Java提供了对网络支持的无平台相关性的完整软件包,使程序员没有必要为系统网络支持的细节而烦恼。Java软件包内在支持的网络协议为TCP/IP,也是当今最流行的广域网/局域网协议。Java有关网络的类及接口定义在包中。客户端软件通常使用包中的核心类Socket与服务器的某个端口建立连接,而服务器程序不同于客户机,它需要初始化一个端口进行监听,遇到连接呼叫,才与相应的客户机建立连接。J包的ServerSocket类包含了编写服务器系统所需的一切。下面给出ServerSocket类的部分定义。publicclassServerSocketpublicServerSocket(intport)throwsIOException;publicSocketaccept()throwsIOException;publicInetAddressgetInetAddress();publicintgetLocalPort();publicvoidclose()throwsIOException;publicsynchronizedvoidsetSoTimeout(inttimeout)throwsSocketException;publicsynchronizedintgetSoTimeout()throwsIOException;ServerSocket构造器是服务器程序运行的基础,它将参数port指定的端口初始化作为该服务器的端口,监听客户机连接请求oPort的范围是0到65536,但0到1023是标准Internet协议保留端口,而且在Unix主机上,这些端口只有root用户可以使用。一般自定义的端口号在8000到16000之间。仅初始化了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的实例,直到该用户结束连接。/类receiveServerimportjava.io.*;importjava.util.*;.*;publicclassreceiveServerfinalintRECEIVE_PORT=9090;/该服务器的端口号/receiveServer的构造器publicreceiveServer()ServerSocketrServer=null;/ServerSocket的实例Socketrequest=null;/用户请求的套接字ThreadreceiveThread=null;tryrServer=newServerSocket(RECEIVE_PORT);/初始化ServerSocketSystem.out.println("Welcometotheserver!");System.out.println(newDate();System.out.println("Theserverisready!");System.out.println("Port:"+RECEIVE_PORT);while(true)/等待用户请求request=rServer.accept();/接收客户机连接请求receiveThread=newserverThread(request);/生成serverThread的实例receiveThread.start();/启动serverThread线程catch(IOExceptione)System.out.println(e.getMessage();publicstaticvoidmain(Stringargs)newreceiveServer();/endofmain/endofclass/类serverThreadimportjava.io.*;.*;classserverThreadextendsThreadSocketclientRequest;/用户连接的通信套接字BufferedReaderinput;/输入流PrintWriteroutput;/输出流publicserverThread(Sockets)/serverThread的构造器this.clientRequest=s;/接收receiveServer传来的套接字InputStreamReaderreader;OutputStreamWriterwriter;try/初始化输入、输出流reader=newInputStreamReader(clientRequest.getInputStream();writer=newOutputStreamWriter(clientRequest.getOutputStream();input=newBufferedReader(reader);output=newPrintWriter(writer,true);catch(IOExceptione)System.out.println(e.getMessage();output.println("Welcometotheserver!");/客户机连接欢迎词output.println("Nowis:"+newjava.util.Date()+""+"Port:"+clientRequest.getLocalPort();output.println("WhatcanIdoforyou?");publicvoidrun()/线程的执行方法Stringcommand=null;/用户指令Stringstr=null;booleandone=false;while(!done)trystr=input.readLine();/接收客户机指令catch(IOExceptione)System.out.println(e.getMessage();command=str.trim().toUpperCase();if(str=null|command.equals("QUIT")/命令quit结束本次连接done=true;elseif(command.equals("HELP")/命令help查询本服务器可接受的命令output.println("query");output.println("quit");output.println("help");elseif(command.startsWith("QUERY")/命令queryoutput.println("OKtoquerysomething!");/elseif./在此可加入服务器的其他指令elseif(!command.startsWith("HELP")&&!command.startsWith("QUIT")&&!command.startsWith("QUERY")output.println("CommandnotFound!PleaserefertotheHELP!");/endofwhiletryclientRequest.close();/关闭套接字catch(IOExceptione)System.out.println(e.getMessage();command=null;/endofrun启动该服务器程序后,可用telnetmachineport命令连接,其中machine为本机名或地址,port为程序中指定的端口。也可以编写特定的客户机软件通过TCP的Socket套接字建立连接。

注意事项

本文(多线程服务器程序)为本站会员(s****a)主动上传,装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知装配图网(点击联系客服),我们立即给予删除!

温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服 - 联系我们

copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!