开发者社区> 问答> 正文

K & R,8.5,_fillbuf()的实现的一个疑问?

书中关于_fillbuf(FILE *p)的实现是这样的:

typedef struct _iobuf {
    int     cnt;
    char    *ptr;
    char    *base;
    int     flag;
    int     fd;
} FILE;
extern FILE _iob[OPEN_MAX];

enum _flags {
    _READ   = 01,
    _WRITE  = 02,
    _UNBUF  = 04,
    _EOF    = 010,
    _ERR    = 020
};

int _fillbuf(FILE *fp) {
    int bufsize;

    if ((fp->flag & (_READ | _EOF | _ERR)) != _READ)    // ?
        return EOF;
    bufsize = (fp->flag & _UNBUF) ? 1 : BUFSIZ;
    if (fp->base == NULL)
        if ((fp->base = (char *) malloc(bufsize)) == NULL)
            return EOF;
    fp->ptr = fp->base;
    fp->cnt = read(fp->fd, fp->ptr, bufsize);
    if (--fp->cnt < 0) {
        if (fp->cnt == -1)
            fp->flag |= _EOF;
        else
            fp->flag |= _ERR;
        fp->cnt = 0;
        return EOF;
    }
    return (unsigned char) *fp->ptr++;
}
其中的这一行我不是很理解:

if ((fp->flag & (_READ | _EOF | _ERR)) != _READ)
难道这和

if (!(fp->flag & _READ))

不是等价的吗?我不太理解为什么书中要向上上式这么写?求教。

展开
收起
a123456678 2016-06-24 15:00:38 1885 0
1 条回答
写回答
取消 提交回答
  • if ((fp->flag & (_READ | _EOF | _ERR)) != _READ)
    fp->flag必须包含_READ并且不能有_EOF和_ERR
    if (!(fp->flag & _READ))
    fp->flag不能包含_READ
    if (fp->flag & _READ)
    fp->flag必须包含_READ(但也可以包含其他的)
    2019-07-17 19:47:00
    赞同 展开评论 打赏
问答地址:
问答排行榜
最热
最新

相关电子书

更多
低代码开发师(初级)实战教程 立即下载
冬季实战营第三期:MySQL数据库进阶实战 立即下载
阿里巴巴DevOps 最佳实践手册 立即下载