linux习题----包含缓冲区知识点

fprintfs输入的数据要先进入一个缓冲区所以它输出完后要加一个fflush 给它冲刷一下!强制刷新缓冲区!!!!!

缓冲区

之所以stdin是0,是因为此时没有输入操作,就不会开辟这个空间。

./a.out >buf.txt   输出重定向

./a.out >>buf.txt   输出重定向   (追加的方式)

./a.out <buf.txt  输入重定向

./a.out <<buf.txt   输入重定向 ( 追加的方式)

缓冲区1024(1k)  变成4096(4k)了

#include <stdio.h>
#include <string.h>
#include <time.h>
#include <unistd.h>

int lineCnt(FILE *fp)
{
	int cnt = 0; 
	char buf[10];

	while (fgets(buf,sizeof(buf),fp) != NULL)
	{
		if (buf[strlen(buf) - 1] == '\n')
			cnt++;
	}

	return cnt;
}


void do_log(FILE *fp)
{
	//1.统计行数 
	int lines = lineCnt(fp);
	//2.输出数据 
	
	while (1)
	{
		time_t t = time(NULL);
		struct tm *ptm = localtime(&t);

		lines++;
		fprintf(stdout,"%d,%04d-%02d-%02d %02d:%02d:%02d\n",lines,ptm->tm_year+1900,ptm->tm_mon+1,ptm->tm_mday,ptm->tm_hour,ptm->tm_min,ptm->tm_sec);
		fprintf(fp,"%d,%04d-%02d-%02d %02d:%02d:%02d\n",lines,ptm->tm_year+1900,ptm->tm_mon+1,ptm->tm_mday,ptm->tm_hour,ptm->tm_min,ptm->tm_sec);
		fflush(fp);
		sleep(1);

	}
}

//./a.out 1.txt 
int main(int argc, const char *argv[])
{
	if (argc != 2)
	{
		printf("Usage: %s <filename>\n",argv[0]);
		return -1;
	}


	FILE *fp = fopen(argv[1],"a+");

	if (fp == NULL)
	{
		perror("fopen fail");
		return -1;
	}

	do_log(fp);

	fclose(fp);
	
	return 0;
}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值