1.用fgetc和fputc实现,拷贝一个文件,以1.c与2.c为例
#include<stdio.h>
#include<string.h>
int main(int argc, const char *argv[])
{
//打开文件1.c与2.c 以追加些与读的方式
FILE *fp1 = fopen("1.c", "a+");
FILE *fp2 = fopen("2.c", "a+");
if(NULL == fp1)
{
printf("1.c打开失败\n");
perror("fopen");
return -1;
}
if(NULL == fp2)
{
printf("2.c打开失败\n");
perror("fopen");
return -1;
}
//功能部分
char c = fgetc(fp1); //fgetc函数,用于取出文件中的字符
while(1)
{
fputc(c, fp2); //把字符输入2.c
c = fgetc(fp1);
if(c < 0) //当文件取完以后,此时的c=-1
{
break;
}
}
//关闭
if(fclose(fp1) < 0)
{
perror("fclose");
return -1;
}
if(fclose(fp2) < 0)
{
perror("fclose");
}
return 0;
}
2:用fgetc计算文件大小,封装成函数
我只展示函数部分
int my_size(FILE *fp)
{
int counst = 0;
char c;
while(1)
{
c = fgetc(fp); //不断去除文件内部的字符
if(c < 0) //当取完后,超界的第一个c=-1,结束循环
{
break;
}
counst++; //判断c没有取超界,再自增
}
return counst;
}
3:fgetc计算文件有几行,封装成函数(Linux操作系统以 '\n' 结尾,即便是最后一行,也有一个 '\n' )
int my_n(FILE *fp)
{
char c;
int counst=0;
while(1)
{
c = fgetc(fp);
if(c == '\n') //相比于上一题,改为统计\n的数量,万变不离其宗
{ //与上一问,本质上是同一题
counst++;
}
if(c < 0)
{
break;
}
}
return counst;
}
4:fgets和fputs实现,拷贝文件
#include<stdio.h>
#include<string.h>
int main(int argc, const char *argv[])
{
//打开
FILE *fp1 = fopen("1.c", "r");
FILE *fp2 = fopen("3.c", "w");
if(NULL == fp1)
{
printf("1.c打开失败\n");
perror("fopen");
return -1;
}
if(NULL == fp2)
{
printf("2.c打开失败\n");
perror("fopen");
return -1;
}
//功能段
char arr[20];
while(fgets(arr, sizeof(arr), fp1) != NULL) //当fgets取出的值是空时,结束
{
fputs(arr, fp2);
}
//关闭
if(fclose(fp1) < 0)
{
perror("fclose");
return -1;
}
if(fclose(fp2) < 0)
{
perror("fclose");
}
return 0;
}
5:用fgets计算文件大小,要求封装成函数
int my_size(FILE *fp)
{
int counst;
char c[2]; //与fgetc相同,一次只取一个字符,但是因为fgets会自动补一个\0
while(fgets(c, sizeof(c), fp) != NULL) //所以数组大小为2
{
counst++;
}
return counst;
}
6:用fgets计算文件行数
万变不离其宗,不多说
int my_line(FILE *fp)
{
char c[2];
int counst = 0;
while(fgets(c, sizeof(c), fp) != NULL)
{
if(c[0] == '\n')
{
counst++;
}
}
return counst;
}