linux下使用read函数实现的按行读取readline

来源:互联网 发布:淘宝的水印设置在哪 编辑:程序博客网 时间:2024/06/15 00:57

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

0 0
原创粉丝点击