- 1、本文档共28页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
学位论文-操作系统课程设计聊天室系统设计报告
青 岛 科 技 大 学
操 作 系 统 课 程 设 计
学生班级 计算机132班
学生学号 1308010204
学生姓名 王永远
______年 ___月 ___日
目录
设计题目:聊天室系统 3
一、设计目的及要求 3
1.1设计目的 3
1.2设计要求: 3
二、技术背景 3
2.1网络编程 3
2.2网络通信 3
2.3 Socket 3
2.4 TCP传输 4
2.5 Java的多线程机制 4
三、需求分析 4
3.1客户端 4
3.1.1登录 4
3.1.2多人聊天 4
3.1.3单人聊天 5
3.2服务器端 5
四、总体设计 5
4.1设计思想流程图 5
4.2设计思想分析 6
五、详细设计 6
5.1客户端设计 7
5.1.1登录界面 7
5.1.2聊天室界面 7
5.1.3单人聊天界面 7
5.2服务器端设计 8
六、系统测试 8
6.1登录测试 8
6.1.1用户名为英文字母 8
6.1.2用户名为中文 9
6.1.3用户名为标点符号 9
6.1.4多个用户有重名 10
6.1.5服务器地址不合法 11
6.1.6端口号不合法 12
6.1.7服务器未开启 12
6.2群发消息测试 13
6.3私聊测试 15
6.4用户列表显示测试 16
七、心得体会 16
八、参考资料 16
九、程序清单 16
设计题目:聊天室系统
一、设计目的及要求
1.1设计目的
通过该聊天室系统,掌握网络编程的概念及基于网络的C/S模式软件系统开发,掌握基于TCP协议的Socket编程,掌握Java的多线程机制。
1.2设计要求:
实现多个用户之间类似于QQ的聊天程序,有聊天界面,多用户之间既可以实现群聊,也可以单独聊天。
二、技术背景
2.1网络编程
就是用来实现网络互连的不同计算机上运行的程序间可以进行数据交换。
2.2网络通信
(1)IP地址:网络中设备的标识,不易记忆,可用主机名
要想让网络中的计算机能够互相通信,必须为每台计算机指定一个标识号,通过这个标识号来指定要接受数据的计算机和识别发送的计算机,在TCP/IP协议中,这个标识号就是IP地址。
(2)端口号:用于标识进程的逻辑地址
物理端口 网卡口
逻辑端口 我们指的就是逻辑端口
A:每个网络程序都会至少有一个逻辑端口
B:用于标识进程的逻辑地址,不同进程的标识
C:有效端口:0~65535,其中0~1024系统使用或保留端口。
(3)传输协议:通信的规则,常见的有UDP,TCP
UDP:将数据源和目的封装成数据包中,不需要建立连接;每个数据报的大小在限制在64k;因无连接,是不可靠协议;不需要建立连接,速度快。
TCP:建立连接,形成传输数据的通道;在连接中进行大数据量传输;通过三次握手完成连接,是可靠协议;必须建立连接,效率会稍低。
2.3 Socket
(1)Socket套接字
网络上具有唯一标识的IP地址和端口号组合在一起才能构成唯一能识别的标识符套接字。
(2)Socket原理机制
A:通信的两端都有Socket。
B:网络通信其实就是Socket间的通信。
C:数据在两个Socket间通过IO传输。
2.4 TCP传输
(1)客户端思路
A建立客户端的Socket服务,并明确要连接的服务器。
B如果连接建立成功,就表明,已经建立了数据传输的通道.就可以在该通道通过IO进行数据的读取和写入.该通道称为Socket流,Socket流中既有读取流,也有写入流.
C通过Socket对象的方法,可以获取这两个流
D通过流的对象可以对数据进行传输
E如果传输数据完毕,关闭资源
(2)服务器端思路
A建立服务器端的socket服务,需要一个端口
B服务端没有直接流的操作,而是通过accept方法获取客户端对象,在通过获取到的客户端对象的流和客户端进行通信
C通过客户端的获取流对象的方法,读取数据或者写入数据
D如果服务完成,需要关闭客户端,然后关闭服务器,但是,一般会关闭客户端,不会关闭服务器,因为服务端是一直提供服务的
2.5 Java的多线程机制
进程:每个进程都有独立的代码和数据空间(进程上下文),进程间的切换会有较大的开销,一个进程包含1--n个线程。
线程:同一类线程共享代码和数据空间,每个线程有独立的运行栈和程序计数器(PC),线程切换开销小。
多进程是指操作系统能同时运行多个任务(程序),多线程是指在同一程序中有多个顺序流在执行。在java中,每次程序运行至少启动2个线程。一个是main线程,一个是垃圾收集线程。因为每当使用java命令执行一个类的时候,实际上都会启动一个JVM,启动JVM实际上就是在操作系统中启动了一个进程。在java中所有的线
文档评论(0)