文档详情

信息检索与搜索引擎技术_实验1多线程编程.doc

发布:2017-08-05约3.89千字共4页下载文档
文本预览下载声明
XXXX大学信息工程与自动化学院学生实验报告 课程名称:搜索引擎技术基础 实验项目名称 多线程编程 指导教师 教师评语 该同学是否了解实验原理: A.了解□ B.基本了解□ C.不了解□ 该同学的实验能力: A.强 □ B.中等 □ C.差 □ 该同学的实验是否达到要求: A.达到□ B.基本达到□ C.未达到□ 实验报告是否规范: A.规范□ B.基本规范□ C.不规范□ 实验过程是否详细记录: A.详细□ B.一般 □ C.没有 □ 教师签名: 年 月 日 一、上机目的和要求 1.掌握Socket通信原理; 2.掌握并实现多线程编程技术。 实验原理 1、通过Socket通信实现客户端与服务器端的通信。 Socket通信分为ServerSocket和Socket两部分,ServerSocket类 提供TCP连接服务,Socket类提供进行通信的Socket对象。建立TCP连接的各个步骤:: (1)服务器创建一个ServerSocket对象,指定端口号,ServerSocket 对象等待客户端的连接请求。 (2)客户端创建一个Socket对象,指定主机地址和端口号,向服务端发出连接请求。 (3)服务端接收到客户端的连接请求,建立一条TCP连接,再创建一个 Socket 对象与客户端的Socket对象进行通信。 (4)当一方决定结束通信,向对方发送结束信息;另一方接收到结束信 息后,双方分别关闭各自的TCP连接。 (5)ServerSocket对象停止等待客户端的连接请求。作为服务器首先构造一个提供TCP连接服务的ServerSocket对象, 然后指定其端口号,如果接收到客户端的连接请求,则建立一条TCP连接,再创建一个Socket对象与客户端的Socket对象进行通信,然后将从文件中读入的数据传送给客户端。由于服务器需要一直等待连接,所以需要监听端口请求。 2、实现服务器端对客户端的多线程技术。 线程:程序中单个顺序的流控制,是最小的执行单位;同类的多个线程共享一块内存空间和一组系统资源;线程独享的资源只有:寄存器,系统堆栈。 多线程:程序中多个片断同时执行。 多线程实现方法:创建一个实现Runnable 接口的类,该接口中只有 一个方法:public void run();已实现的run方法称为线程体,而实现了Runnable接口的对象称为线程的目标对象。将实现了Runnable接口的类的实例作为Thread类构造函数的参数创建线程对象,调用该对象的start()方法启动线程 三、所用仪器、材料(设备名称、型号、规格等或使用软件) PC机一台、MyEclipse 四、实验过程截图 五、源代码 EchoThreadServer.java import java.net.* ; import java.io.* ; public class EchoThreadServer{ public static void main(String args[]) throws Exception { // 所有异常抛出 ServerSocket server = null ; // 定义ServerSocket类 Socket client = null ; // 表示客 户端 server = new ServerSocket(8888) ; // 服务器在8888端口上监听 boolean f = true ; // 定义个标记位 while(f){ System.out.println(服务器运行,等待客户端连接。) ; client = server.accept() ; // 得到连接,程序进入到阻塞状态 new Thread(new EchoThread(client)).start() ; // 每一个客户端表示一个线程 } server.close() ; } }; EchoClient.java import java.net.* ; import java.io.* ; public class EchoClient{ public static void main(String args[]) throws Exception { // 所有异常抛出 Socket client = null ; // 表示客 户端 clien
显示全部
相似文档