Linux中getline源码实现

ssize_t mygetline(char **lineptr, size_t *n, FILE *stream)
lineptr是存储字符的指针的地址,*lineptr本身就自带空间,n是代表lineptr开辟的存储字节数大小,如果不足以读取一行,getline会再次开辟空间,stream是要读的文件的文件流。

#include <stdio.h>
#include <stdlib.h>
#include <string.h>

#define BUFSIZE 32
#define SPACE 64

ssize_t mygetline(char **lineptr, size_t *n, FILE *stream);

int main(int argc, char *argv[])
{
	FILE *fp = NULL;
	char *lineptr = NULL;
	size_t n = 0;
	int cnt;
	
	if(argc < 2)
		return -1;
	fp = fopen(argv[1], "r");
	if(NULL == fp)
		return -1;
	while(1)
	{
		cnt = mygetlen(&lineptr, &n, fp);
		if(cnt == -1)
			break;
		else
			fputs(lineptr, stdout);
	}
	free(lineptr);
	lineptr = NULL;
	fclose(fp)

	return 0;
}
ssize_t mygetline(char **lineptr, size_t *n, FILE *stream)
{
	int i = 0;//代表*lineptr中存储了多少元素。
	char buf[BUFSIZE] = {};
	char *p = NULL;
	int buf_cnt;
	
	while(1)
	{
		p = fgets(buf, BUFSIZE, stream);
		if(NULL == p)
			return -1;
		buf_cnt = strlen(buf);
		if(buf_cnt + i >= *n)
		{
			*n += SPACE;
			*lineptr = realloc(*lineptr, *n);
		}
		strncpy((*lineptr) + i, buf, buf_cnt);
		i += buf_cnt;
		if((*lineptr)[i - 1] == '\n')
		{
			(*lineptr)[i] = '\0';
			break;
		}
	}
	if(feof(stream) || ferror(stream))
	return -1;

	return i;
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值