网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > Java
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
网络编程:ASP教程,ASP.NET教程,PHP教程,JSP教程,C#教程,数据库,XML教程,Ajax,Java,Perl,Shell,VB教程,Delphi,C/C++教程,软件工程,J2EE/J2ME,移动开发
本月文章推荐
.JNI开发简单入门.
.理解JDIC中的文件类型关联.
.JAVA的XML编程.
.Hibernate 入门(1).
.Java 理论与实践: 哈希.
.JForum 2.1.7 源程序编译草记.
.利用HSQLDB进行Hibernate的单元测.
.Java语言基础 对于JAVA基础知识精.
.《Effective Java》学习笔记(3).
.什么是Servlet以及Servlet的优越.
.Hacking swing: 一个J.
..NET实现的农历功能及其代码分享.
.爪哇语言结构性模式之变压器模式.
.JSR-184中纹理对象介绍.
.剖析事件监听和匿名类.
.用JavaBean实现文件上载(二)上载.
.在solairs上运行linux上的二进制.
.Java程序开发中代理技术的使用方.
.Java入门及faq__1(3).
.javascript+xml实现二级下拉菜单.

JavaSocket编程(四)重复和并发服务器

发表日期:2008-1-5



  重复和并发服务器
  这个应用程序被当作一个重复的服务器.因为它只有在处理完一个进程以后才会接受另一个连接.更多的复杂服务器是并发的.它为每一个请求分配一个线程,而不是来一个处理一个.所以看起来它在同时处理多人请求.所有的商业的服务器都是并发的服务器.
  Java数据报类
  不像面向连接的类,数据报的客户端和服务器端的类在表面上是一样的.下面的程序建立了一个客户和服务器商的数据报sockets:
  DatagramSocket serverSocket = new DatagramSocket( 4545 );
  DatagramSocket clientSocket = new DatagramSocket();
  
  服务器用参数4545来指定端口号,由于客户端将要呼叫服务器,客户端可以利用可利用的端口.假如省略第二个参数,程序会让操作系统分配一个可用的端口.客户端可以请求一个指定的端口,但是假如其它的应用程序已经绑定到这个端口之上,请求将会失败.假如你的意图不是作为一个服务器,最好不要指定端口.
  由于流不能由交谈得到,那么我么如何与一个数据报Socket进行对话.答案在于数据报类.
  接收数据报
  DatagramPacket类是用来通过DatagramSocket类接收和发送数据的类.packet类包括了连接信息和数据.就如前面所说的一样,数据报是自身独立的传输单元.DatagramPacket类压缩了这些单元.下面的程序表示了用一个数据报socket来接收数据:
  DatagramPacket packet = new DatagramPacket(new byte[512], 512); clientSocket.receive(packet);
  clientSocket.receive(packet);
  packet的构建器需要知道将得到的数据放在哪儿.一个512字节的缓存被建立并且作为构建器的第二个参数.每二个构建器参数是缓存的大小.就像ServerSocket类的accept()方法一样,receive()方法在数据可用之前将会阻塞.
  发送数据报
  发送数据报是非常地简单地,所有需要的只是一个地址.地址是由InetAddress类来建立的.这个类没有公共的构建器,但是它有几个static的方法,可以用来建立这个类的实例.下面的列表列出了建立InetAddress类的实例的方法:
  Public InetAddress Creation Methods
  InetAddress getByName(String host);
  InetAddress[] getAllByName(String host);
  InetAddress getLocalHost();
  得到本地主机的地址是非常地有用的,只有前面两个方法是用来发送数据包的.getByName()和getAllByName()需要目的主机的地址.第一个方法仅仅只是返回第一个符合条件的东西.第二个方法是必须的,因为一台计算机可能有多个地址.在这种情况下,这台计算机被称为multi-homed.
  所有的建立的方法都被标记为static.它们必须像下面这样得到调用:
  InetAddress addr1 = InetAddress.getByName("merlin");
  InetAddress addr2[] = InetAddress.getAllByName("merlin");
  InetAddress addr3 = InetAddress.getLocalHost();
上一篇:利用UDPSockets技术实现IP多点传送 人气:618
下一篇:使用档案文件提高applet的加载速度 人气:524
浏览全部Java的内容 Dreamweaver插件下载 网页广告代码 祝你圣诞节快乐 2009年新年快乐