书中关于_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))
不是等价的吗?我不太理解为什么书中要向上上式这么写?求教。
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(但也可以包含其他的)
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。