多进程网络编程

18 篇文章 0 订阅
17 篇文章 0 订阅

本文概述如何使 服务器同时 连接处理 客户端们。

       即服务器的一个进程只负责接受 请求连接的客户端。而具体如何跟各个客户端发送数据交给自己创造的子进程去完成。

       用TCP协议来举例。

       服务器在创造套接字,并用套接字创建监听队列后,陷入循环,循环里负责的是只要accept接受到了客户端的链接,就会fork出一个子进程,子进程里和客户端去具体的send recv。而父进程则进入下一次循环里继续accept等待新的客户端连接加入。

      由于父进程共享文件描述符,所以不必要传递文件描述符。

      父进程创建出子进程后,由于父子进程的pcb是浅拷贝,父子进程的pcb结构体 某一项成员指针struct file*  共同指向同一个struct file结构体,这个file结构体里某个成员结构指针指向的struct m_iode才是打开文件的各种信息,所以file结构体里会有个 count成员 统计所有指向 file结构体的指针,只有所有指向file的指针都失效才会彻底关闭这个文件,释放占用的 文件描述符,因此不仅要子进程close(c),父进程也要在进入下一次循环前close(c),这里的c指的是accept返回的文件描述符。

   


    服务器端代码:




客户端代码:



结果如下:

2个客户端程序cli都同时连入


我们再看看是否能同时保持连接,同时发送单词。



 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值