当然是站在文件的角度啊。
需要导入的头文件
假设有结构体:
结构体写入文件的方法:
函数fopen是一个标准c函数,其功能是打开一个文件,之后便可以进行读或写的 *** 作.其原型是这样的:FILE *fopen( const char *filename, const char *mode )
第一个参数是要打开文件的名字(路径),第二个参数是打开文件所用的模式.对于模式参数的”w”和”wb”,”r”和”rb”,我起初并不是很理解,按照课本上的说法,”w”是以文本的形式进行写入,而”wb”是以二进制模式进行写入.这样的解释令人感觉有点玄乎,不能准确理解.
最近写了个小程序,把数据以16进制的形式存到一个文件中,当从文件中读取时,发现读取的数据不对,进行调试时,发现读取的数据与写入文件中的数据发生了错位,进行调试发现写入时并没有错误,读取时,怎么就发生错位了呢?调试了半天发现每遇到0x0A,在它前面就会多一个0x0D.
那么,是什么原因造成的呢?几经周折之后,终于发现是fopen的参数引起的.如果这么写:fp = fopen(str,"wb")可以得到正常数据,而fp = fopen(str,"w")就得不到正常数据,遇到0x0A时,就会在其前面多一个0x0D.
原来,如果有参数b,是以二进制方式打开,这种方式不会进行”回车符”和”换行符”的转换.而如果没有b,即单以”w”为参数的话,系统就把换行符0A转换为0D0A,因为windows是以0D0A为换行符的.
fgets()与fputs()
gets()与puts()一起
scanf是接受的单词 遇空格也会停止
楼下这个人真的装,不会就算了还在这水,你还是去打斗地主吧!这个题简单,用fgetc函数直接进行循环写入就行了,话说贴主是湖工大的吧?这是实训题,你还是自己打一下吧,下面是参考答案:
#include<stdlib.h>
#include<stdio.h>
void solve(){
FILE *fp1,*fp2
fp1=fopen("a.txt","r")
fp2=fopen("b.txt","w")
char c
c=fgetc(fp1)
while(c!=EOF)
{
fputc(c,fp2)
c=fgetc(fp1)
}
fclose(fp1)
fclose(fp2)
}
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)