由于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