文件IO-流刷新定位、格式化输入输出(篇3)

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档

目录

前言

流的刷新

流的定位:

格式化输出

格式化输入

标准IO练习

总结


前言

提示:

例如:。


1.流的刷新

 int fflush(FILE *fp);

成功时返回0;出错时返回EOF

将流缓冲区中的数据写入实际的文件

Linux下只能刷新输出缓冲区,输入缓冲区丢弃

如果输出到屏幕使用fflush(stdout)

2.流的定位:

long ftell(FILE *stream);

long fseek(FILE *stream, long offset,  int whence);

void rewind(FILE *stream);

fseek 参数whence参数:SEEK_SET/SEEK_CUR/SEEK_END

SEEK_SET 从距文件开头 offset 位移量为新的读写位置

SEEK_CUR:以目前的读写位置往后增加 offset 个位移量

SEEK_END:将读写位置指向文件尾后再增加 offset 个位移量

offset参数:偏移量,可正可负

注意事项:

1.文件的打开使用a模式 fseek无效

2.rewind(fp) 相当于 fseek(fp,0,SEEK_SET);

3.这三个函数只适用2G以下的文件

编译告警错误:

ffseek_t.c:13:11: warning: format ‘%d’ expects argument of type ‘int’, but argument 2 has type ‘long int’ [-Wformat=]

    printf("current fp=%d\n",ftell(fp));

表示参数类型不匹配

练习

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

int main(int argc, const char *argv[])
{
	FILE *fp;
	fp=fopen("1.txt","w");
	if(fp == NULL){
	perror("ffseek: ");
	return 0;
	}
	fwrite("abcdef",6,1,fp);
	//fseek(fp,-2,SEEK_CUR);//abcdvvv
	//fseek(fp,3,SEEK_SET);//abcvvv
	//fseek(fp,0,SEEK_SET);//vvvdef
    //fwrite("vvv",3,1,fp);
	printf("当前fp位置fp=%ld\n",ftell(fp));//6
	rewind(fp);
	printf("当前fp位置fp=%ld\n",ftell(fp));//0
	fwrite("vvv",3,1,fp);

	fclose(fp);
	return 0;
}

3.格式化输出

int printf() 标准输出 到屏幕

int sprintf(char *s, const char *fmt, …);

int fprintf(FILE *stream, const char *fmt, …);

成功时返回输出的字符个数;出错时返回EOF

#include<stdio.h>

int main(int argc, const char *argv[])
{
	char buf[]={0};
	int year = 2022;
	sprintf(buf,"%d",year);
	printf("%s\n",buf);
	return 0;
}
#include<stdio.h>

int main(int argc, const char *argv[])
{
	FILE *fp;
	fp = fopen("1.txt","w");
	if(fp == NULL){
	perror("fprintf:");
	return 0;
	}
	int year = 2022;
	fprintf(fp,"%d",year);

	fclose(fp);
	return 0;
}

4.格式化输入

int scanf() 标准输入 从键盘

int sscanf(const char *str, const char *format, ...);

int fscanf(FILE *stream, const char *format, ...);

重点掌握sprintf 和sscanf

#include<stdio.h>

int main(int argc, const char *argv[])
{
	char buf[]={0};
	int year = 2022;
    int month = 11;
    int day= 6;
	sprintf(buf,"%d-%d-%d",year,month,day);//输出到buf
	printf("%s\n",buf);//打印buf
	sscanf(buf,"%d\n",&year,&month,&day);//从buf输入到变量中
	return 0;
}
#include<stdio.h>

int main(int argc, const char *argv[])
{
	FILE *fp;
	fp = fopen("1.txt","r");
	if(fp == NULL){
	perror("fprintf:");
	return 0;
	}
	int sy,sm,sd;
	fscanf(fp,"%d-%d-%d",&sy,&sm,&sd);
	printf("%d,%d,%d\n",sy,sm,sd);
	fclose(fp);
	return 0;
}

编译告警:

wsystime.c:16:13: warning: format ‘%d’ expects argument of type ‘int’, but argument 2 has type ‘time_t {aka long int}’ [-Wformat=]

      printf("ctime=%d\n",ctime);

表示类型不匹配 期望的是int但是参数传的是time_t

解决办法:在参数前加强制类型转换

5.标准IO练习

time()用来获取系统时间(秒数)

time_t time(time_t *seconds) 1970.1.1 0:0:0

localtime()将系统时间转换成本地时间

struct tm *localtime(const time_t *timer)

struct tm {

   int tm_sec;         /* 秒,范围从 0 到 59                */

   int tm_min;         /* 分,范围从 0 到 59                */

   int tm_hour;        /* 小时,范围从 0 到 23                */

   int tm_mday;        /* 一月中的第几天,范围从 1 到 31                    */

   int tm_mon;         /* 月份,范围从 0 到 11                */

   int tm_year;        /* 自 1900 起的年数                */

   int tm_wday;        /* 一周中的第几天,范围从 0 到 6                */

   int tm_yday;        /* 一年中的第几天,范围从 0 到 365                    */

   int tm_isdst;       /* 夏令时                        */    

};

注意:

   int tm_mon;        获取的值要加1是正确的月份

   int tm_year;        获取的值加1900是正确的年份

获取文件内的所有行数量:

   while(fgets(buf,32,fp)!=NULL){
          if(buf[strlen(buf)-1] =='\n'){  //注意判断是否是一行结束
               linecount++;
          }
}

代码:(这里的hour和实际对不上)

#include<stdio.h>
#include<time.h>
#include<unistd.h>
#include<string.h>
int main(int argc, const char *argv[])
{
	FILE *fp;
	time_t ctime;
	struct tm *ctimestr;
	char buf[32];
	int num = 0;
	
	fp = fopen("1.txt","a+");
	if(fp == NULL){
	 perror("wsystime: ");
	return 0;
	}
	//时间前面加编号,注意:要考虑到前面已有的数据行	
	while(fgets(buf,32,fp) != NULL){//一直读到最后
		if(buf[strlen(buf)-1] == '\n'){//一行结束的就num++
		num++;
		}
	}

	while(1){
	ctime = time(NULL);
	ctimestr = localtime(&ctime);
	printf("%04d-%02d-%02d:%02d-%02d-%02d\n",ctimestr->tm_year+1900,ctimestr->tm_mon+1,ctimestr->tm_mday,
			ctimestr->tm_hour,ctimestr->tm_min,ctimestr->tm_sec);
	//格式化输出
	
	fprintf(fp,"%d,%04d-%02d-%02d:%02d-%02d-%02d\n",num,ctimestr->tm_year+1900,ctimestr->tm_mon+1,ctimestr->tm_mday,
			ctimestr->tm_hour,ctimestr->tm_min,ctimestr->tm_sec);
	num++;
	fflush(fp);//必须刷新缓存区
	sleep(1);	
	}

	return 0;
}

注意:写完文件记得fflush ,写到磁盘里面去。

标准IO磁盘文件的缓冲区一般为4096

注意和标准输出的全缓冲区别,标准输出是1024


总结

提示:这里对文章进行总结:
例如:。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值