版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、Socket通信中的多进程编程实例1 需求描述:(1)Linux下编写。(2)创建一个服务器、若干个客户端。(3)用户可以通过客户端输入文字向服务器发送消息。(4)服务器端接收到客户端发送的数据,将用户输入的内容在服务器上打印出来,并原样返回。2 相关基础2.1 套接字Socket通信编程2.1.1 TCP/IP通信过程: 图2.1.1 TCP/IP通信过程 2.1.2 UDP通信过程:图2.1.2 UDP通信过程 2.2 fork多进程编程fork,在英语中意思是分叉的意思。Linux函数fork(void)被定义在#incl
2、ude<sys/types.h>中,调用成功时,返回两个值,子进程返回0,父进程返回子进程的ID,出错返回-1。子进程是父进程的副本,它将获得父进程的数据空间、堆、栈等资源的副本并且拥有自己独立的地址空间。以下是一个fork的简单例子。fork实例 3 设计3.1 框架设计 图3.1 框架设计 本文使用TCP进行通信。3.2 代码设计 套接口的通信一般使用read( )和write( )。这里使用send(
3、)和recv( ),因为这一对函数可以更好地控制数据传输。 图3.2 代码设计 4 详细代码4.1 服务器端代码 服务器端代码 4.2 客户端代码 客户端代码 5 运行结果Linux下进行编译:gcc Server.c -o servergcc Client.c -o client 运行结果客户端1: 图5.1 客户端1运行结果客户端2: 图5.2 客户端2运行结果服务器端: 图5.3 服务器端运行结果 从上图中可以看到,服务器可以对两个客户端的消息进行相应。6 总结 实例运行,初步达到预期的效果。不足之处:一个IP地址主
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
评论
0/150
提交评论