gpt4 book ai didi

c - K&R fopen 和 fillbuf 中 C 中的段错误

转载 作者:行者123 更新时间:2023-12-05 03:09:47 27 4
gpt4 key购买 nike

我是 C 的新手。我在学习 K&R 的最后一章时遇到了一个问题。

我正在尝试通过使用系统调用、openread< 来实现 fopen()fillbuf() 函数

我照着书上的源码照搬过来,编译后却反复出现段错误。

    fp->fd = fd;
fp->cnt = 0;
fp->base = NULL;
fp->flag = (*mode=='r')? _READ : _WRITE;

为什么会出现错误?这是我的完整代码。

#include<fcntl.h>
#include<unistd.h>
#include<stdlib.h>
#define PERM 0644
#define EOF (-1)
#define BUFSIZE 1024
#define OPEN_MAX 20

typedef struct _iobuf{
int cnt;
char *ptr;
char *base;
int flag;
int fd;
} myFILE;

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

myFILE _iob[OPEN_MAX]={
{0, (char *) 0, (char *) 0, _READ, 0 },
{0, (char *) 0, (char *) 0, _WRITE, 1 },
{0, (char *) 0, (char *) 0, _WRITE | _UNBUF, 2 }
};

#define stdin (&_iob[0])
#define stdout (&_iob[1])
#define stderr (&_iob[2])

#define getc(p) ( --(p)->cnt>=0 ? (unsigned char) *(p)->ptr++ : _fillbuf(p) )

int _fillbuf(myFILE *fp)
{
int bufsize;

if((fp->flag & (_READ|_EOF|_ERR))!=_READ)
return EOF;

bufsize=(fp->flag & _UNBUF)? 1 : BUFSIZE;

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;
return EOF;
}
return (unsigned char) *fp->ptr++;
}

myFILE *myfopen(char *name, char *mode)
{
int fd;
myFILE *fp;

if(*mode!='r' && *mode!='w' && *mode!='a')
return NULL;
for(fp=_iob; fp<_iob+OPEN_MAX; fp++)
if((fp->flag & (_READ | _WRITE))==0)
break;

if(fp>=_iob+OPEN_MAX)
return NULL;

if(*mode=='w')
fd=creat(name, PERM);
else if(*mode=='a'){
if((fd=open(name, O_WRONLY, 0))==-1)
fd=creat(name, PERM);
lseek(fd, 0L, 2);
} else
fd=open(name, O_RDONLY, 0);

if(fd==-1)
return NULL;

fp->fd = fd;
fp->cnt = 0;
fp->base = NULL;
fp->flag = (*mode=='r')? _READ : _WRITE;

return fp;
}

int main(int argc, char *argv[])
{
myFILE *fp;
int c;

if((fp=myfopen(argv[1], "r"))!=NULL)
write(1, "opened\n", sizeof("opened\n"));

while((c=getc(fp))!=EOF)
write(1, &c, sizeof(c));

return 0;
}

最佳答案

编辑:请参阅 Jonathan Leffler's answer .它更准确,并提供更好的诊断。我的答案有效,但还有更好的方法。

我看到了问题。

myFILE *fp;

if(*mode!='r' && *mode!='w' && *mode!='a')
return NULL;
for(fp=_iob; fp<_iob+OPEN_MAX; fp++)
if((fp->flag & (_READ | _WRITE))==0) // marked line
break;

当您到达 marked line ,您尝试取消引用 fp指针。由于它(可能但不确定)初始化为零(但我应该说 NULL ),您正在取消引用空指针。繁荣。段错误。

这是您需要更改的内容。

myFILE *fp = (myFILE *)malloc(sizeof(myFILE));

一定要#include <malloc.h>使用 malloc。

还有你的close功能应该稍后free()你的myFILE以防止内存泄漏。

关于c - K&R fopen 和 fillbuf 中 C 中的段错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41792701/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com