由于linux实验需要用到这个函数,但是又不太想用getline和fgets所以直接写了一个readline的函数,并没有对这个函数进行过效率测试。由于每次都只读取一个字符,然后判断是否是换行符和指针指向的数据空间是否为满,不像直接读取缓冲区,然后在判断的方式,可能我使用的方式速率会慢一些。以后有机会的时候进行下验证。
以下是代码,没有附加注释。
int readline(int fd,char** buff){ int rl=-1; char c; long maxlength=128; long count=0; if(fd<0) { printf(“open file error\n”); exit(0); } *buff=(char*)malloc(sizeof(char)*maxlength); while((rl=read(fd,&c,1))>0) { if(count==maxlength) { maxlength+=128; *buff=(char*)realloc(*buff,maxlength); if(*buff==NULL) { printf(“allocate memory error\n”); close(fd); exit(0); } } (*buff)[count++]=c; if(c==’\n’ || c==EOF) { break; } } (*buff)[count]=’\0′; return count;}
修改1—————————-
之前只读取一段进行测试,没有进行全文的读取测试,刚刚测试了以后修改了代码,在while((rl=read(fd,&c,1))>0)由原来的while((rl=read(fd,&c,1))!=-1)修改而来,因为当读取失败的时候是返回-1,那么读到文件尾的时候应该是返回0,未修改的代码由于没有关注到0这个返回值导致段错误。
修改2——————————
修改读到一个\n后紧接着的\n无法读取的情况。
主要错误是:
if(c==’\n’ || c==EOF) { break; }放在了 (*buff)[count++]=c;之前,直接break掉,没有让count++,所以fan’hui
转载时请附上作者的邮箱:
1305167657@qq.com