明暖橙 2018-11-26 14:15 采纳率: 0%
浏览 1020

linux下实现基于进程的并发服务器模型,当多个client连入服务器时,accept函数返回的套接字描述符相同

基于进程的并发服务器模型代码

        我的代码在上面的链接中,我的问题是:

        基于进程实现了一个并发服务器模型,但是很奇怪的一个现象是,每当新连入一个client,服务器这边调用accpet函数的返回值也就是这个client的套接字描述符都是同一个值,不明白为什么会这样??
  • 写回答

1条回答 默认 最新

  • weixin_43813120 2018-11-27 04:10
    关注

    套接字属于文件描述符,Linux的文件描述符是从小到大自增的,0是标准输入,1是标准输出,2是标准错误输出,依次类推,
    描述符是重复使用的,并且每次从0开始查找。
    当每次客户端连接后,分配了描述符x,然后进行服务,接着关闭此文件描述符,所以下一次调用仍然会使用这个最小的描述符。
    你可以试一下,创建一次连接后将描述符2关闭,看会不会先一个socket套接字=2

    评论

报告相同问题?

悬赏问题

  • ¥15 LiBeAs的带隙等于0.997eV,计算阴离子的N和P
  • ¥15 关于#windows#的问题:怎么用WIN 11系统的电脑 克隆WIN NT3.51-4.0系统的硬盘
  • ¥15 来真人,不要ai!matlab有关常微分方程的问题求解决,
  • ¥15 perl MISA分析p3_in脚本出错
  • ¥15 k8s部署jupyterlab,jupyterlab保存不了文件
  • ¥15 ubuntu虚拟机打包apk错误
  • ¥199 rust编程架构设计的方案 有偿
  • ¥15 回答4f系统的像差计算
  • ¥15 java如何提取出pdf里的文字?
  • ¥100 求三轴之间相互配合画圆以及直线的算法