《linux c 编程实战 》 -我的纠错笔记

《linux c 编程实战 》 -我的纠错笔记

一切仅作为参考,欢迎任何人讨论

 

  [页数] 151     [位置] my_rwl.c [类型]  代码错误     

       [描述]   从书上看 __LINE__,是一个下划线,但实际上内置宏是前后各两个下滑线组成的,即 _ _LINE_ _

 

  [页数] 195     [位置] studyuid.c [类型]  代码错误     

       [描述]   strerror()的头文件是string.h ,需要添加之后才能代码才能运行

 

  [页数] 251    [位置] ctrlpocess.c [类型]  代码错误     

       [描述]   read 的函数声明 :ssize_t read(int fd, void *buf, size_t count),而 stdin 的声明是extern FILE *stdin,因此 read(stdin,buf,1024)不匹配,改成read(0,buf,1024)

 

   [页数] 299   [位置] 中部         [类型]  描述偏差          PS :待讨论

       [描述]   int select(int nfds, fd_set *readfds, fd_set *writefds,fd_set *exceptfds, struct timeval *timeout);

                  对nfds 是这么解释的 :需要监视的文件描述符数,man之后的解释是

                  nfds is the highest-numbered file descriptor in any of the three sets【 在所有的文件描述符中最高值的大小】

                   使用建议:取最大的文件描述符加一

 

   [页数] 299   [位置] 中部         [类型]  描述不足          PS :待讨论

       [描述]  对FD_ISSET( int fd,fd_set *set )是这么解释的: 测试fd是否在set里

                  这么解释是对的,但缺少铺垫容易导致误导,应该再加上一句,select函数之后,会改变 set的值,只保留有状态【可读,可写,异常】的文件描述符, 

                      

socket   s; 
..... 
fd_set   set; 
while(1) 
{     
    FD_ZERO(&set);//将你的套节字集合清空 
    FD_SET(s,   &set);//加入你感兴趣的套节字到集合,这里是一个读数据的套节字s 
    select(0,&set,NULL,NULL,NULL);//检查套节字是否可读, 
                                                      //很多情况下就是是否有数据(注意,只是说很多情况) 
                                                      //这里select是否出错没有写 
    if(FD_ISSET(s,   &set)   //检查s是否在这个集合里面, 
    {                                           //select将更新这个集合,把其中不可读的套节字去掉 
                                                //只保留符合条件的套节字在这个集合里面 
                                
            recv(s,...); 
    
    } 
    //do   something   here 
}

 

               依据[都是根据man之后描述推测的,如果能提供更加可靠的描述,要联系我呀]

             

               一  man 的 description部分

                     Three independent sets of file descriptors are watched. Those listed
                     in readfds will be watched to see if characters become available for
                      reading 【可读文件集中的元素将被检测其是否成文可读文件描述符,】

                      (more precisely, to see if a read will not block; in particu‐
                     lar, a file descriptor is also ready on end-of-file【更加精确的是,看

                     可读设置是否被阻塞,尤其是,对于文件描述符,其文件结尾是否可读】), those in

                     writefds will be watched to see if a write will not block, and those in
                     exceptfds will be watched for exceptions. On exit, the sets are modi‐
                     fied in place to indicate which file descriptors actually changed sta‐
                     tus.【select 函数在推出时,这些文件集合将被修改以便于显示那些文件描述符改变了状态】

              二  man 的 return 部分

                   On success, select() and pselect() return the number of file descrip‐
                   tors contained in the three returned descriptor sets (that is, the
                    total number of bits that are set in readfds, writefds, exceptfds)

                          【 成功的话 ,select和pselect函数将返回包含在三个文件集合中的文件描述符个数】

 

 

 

转载于:https://www.cnblogs.com/dilidingzhi/p/4263290.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/109565.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 什么是GMM算法_bs模型公式

    什么是GMM算法_bs模型公式1.高斯模型与高维高斯模型介绍高斯模型也就是正态分布模型,该模型最早可见于我们的高中数学教材中。闻其名知其意,正态分布是自然界中普遍存在的一种分布。比如,考试成绩,人的智力水平等等。都是大致呈现为正态分布。其概率密度函数为其中参数为μ,σ2,都是一维标量。对于高维高斯模型,与一维类似,只是自变量变成了多维,是一个向量。其概率密度函数为其中参数为μ…

    2025年6月6日
    0
  • Python进制转换和补零「建议收藏」

    Python进制转换和补零「建议收藏」1、补零1)字符串python中有一个zfill方法用来给字符串前面补0,非常有用n=”123″s=n.zfill(5)asserts==”00123″zfill()也可以给负数补0n=”-123″s=n.zfill(5)asserts==”-0123″2)数字补零通过格式化的方式来补0n=123s=”%05d”…

    2022年5月12日
    315
  • css元素水平垂直居中的十种方法

    css元素水平垂直居中的十种方法

    2022年3月11日
    62
  • Java面试宝典4.0版

    Java面试宝典4.0版JAVA面试宝典V4.0版本基础1.简述JDK跟JRE的区别Jdk是java开发人员在开发过程使用的软件开发包,他提供了java的开发环境和运行环境JRE是JavaRuntimeEnviroment是指Java的运行环境如果你只想跑java程序,只要安装jre就够了,如果要从事开发就得安装jdk2.简述path跟classpat…

    2022年9月20日
    0
  • Elasticsearch搜索引擎:ES的segment段合并原理

    Elasticsearch搜索引擎:ES的segment段合并原理

    2021年10月5日
    155
  • SQL like子查询

    SQL like子查询like子查询字符匹配:%(百分号)任意字长度(可以为0)的字符_(下横线)代表任意单个字符eg:a%b表示以a开头,以b结尾的任意长度的字符。三个常用的字符串截取函数:substr(column,1,n)left(column,n)right(column,n)str=’abcdefg’substr(str,1,3):’bcd’left(s…

    2022年7月13日
    56

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号