1.函数功能
用来读写一个数据块。
2.一般调用形式
fread(buffer,size,count,fp)
fwrite(buffer,size,count,fp)
3.说明
(1)buffer:是一个指针,对fread来说,它是读入数据的存放地址。对fwrite来说,是要输出数据的地址。
(2)size:要读写的字节数;
(3)count:要进行读写多少个size字节的数据项;
(4)fp:文件型指针。
注意:1 完成次写 *** (fwrite())作后必须关闭流(fclose())
2 完成一次读 *** 作(fread())后,如果没有关闭流(fclose()),则指针(FILE * fp)自动向后移动前一次读写的长度,不关闭流继续下一次读 *** 作则接着上次的输出继续输出
3 fprintf() : 按格式输入到流,其原型是int fprintf(FILE *stream, const char *format[, argument, ...])其用法和printf()相同,不过不是写到控制台,而是写到流罢了。
注意的是返回值为此次 *** 作写入到文件的字节数。如int c = fprintf(fp, "%s %s %d %f", str1,str2, a, b) str1:10字节;str2: 10字节;a:2字节;b:8字节,c为33,因为写入时不同的数据间自动加入一个空格。
我提个思路。字节是计算机 *** 作的实际最基本单位,任何地址只能精确到字节而无法精确到位的。所以LZ一定要将位整合到以字节为单位才能进行其他 *** 作。可以这么做,将二进制流按照每8位一个单位装成一个字节,并明确好字节之间的顺序,字节内高低位的顺序,最后末尾不足的要塞一些没意义的但LZ要知道的位凑足成字节。这里面当然必须反复用到位运算。
通常的做法是字节之间的顺序按照自然字节地址由小到大顺序,字节内低位在前。比如对于已经整合成字节的字节流a[N],查看第 i 个位(从0起)的算法是 a[i/8] &(1<<(i%8))。
不同的位序约定会稍有不同位 *** 作
你对文件的本质认识不清文本文件本身就是二进制文件 他们是没有区别的 都是1和0的组合
只是文本文件的所有数据都是字符char类型数据罢了
由于你写出的是字符串 而字符串是一个字符占一字节 因此能够用记事本打开
如果你写的不是字符 而是int float short类数据 用记事本打开就是乱码 因为一个int四个字节 如果用记事本打开 那么一个int数据就读成了四个字符串 当然就是乱码了 但是char数据占一个字节 所以当然就能正常显示了
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)