先来做两个个小小的实验:
实验一:
首先,用鼠标右键新建一个文本文档,取名去test.txt, 在里面写一个0, 然后关闭.
然后,用UltraEdit打开test.txt, 用十六进制观察,发现是0x30(十进制数值是48) .
可见,0在test.txt文件对应的硬盘中存得实际比特是00110000
沉思中......
实验二:
运行下面程序:
- #include<stdio.h>
-
- int main()
- {
- FILE *fp = fopen("test", "wb");
- fputc(48, fp);
- fclose(fp);
-
- return 0;
- }
用鼠标右击test文件,选择记事本打开方式,发现结果为0.
沉思中......
写文件的本质是编码,读文件的本质是解码 . 写读二进制文件和写读文本文件其实就是两套不同的编解码方式,仅此而已. 下面用程序来说明:
写读二进制文件程序:
- #include<iostream>
- #define N 10000
- using namespace std;
-
- void write()
- {
- int i, a[N];
- for(i = 0; i < N; i++)
- a[i] = i;
-
- FILE *fp;
- fp = fopen("myData", "wb");
- fwrite(a, sizeof(a), 1, fp);
- fclose(fp);
- }
-
- void read()
- {
- int a[N];
-
- FILE *fp;
- fp = fopen("myData", "rb");
- fread(a, sizeof(a), 1, fp);
- fclose(fp);
-
- int i;
- for(i = 0; i < N; i++)
- cout << a[i] << endl;
- }
-
- int main()
- {
- write();
- read();
-
- return 0;
- }
写读文本文件程序为:
- #include<iostream>
- #define N 10000
- using namespace std;
-
- void write()
- {
- int i, a[N];
- for(i = 0; i < N; i++)
- a[i] = i;
-
- FILE *fp;
- fp = fopen("yourData", "w");
- for(i = 0; i < N; i++)
- fprintf(fp, "%d ", a[i]);
- fclose(fp);
- }
-
- void read()
- {
- FILE *fp;
- fp = fopen("yourData", "r");
- int i, a[N];
- for(i = 0; i < N; i++)
- fscanf(fp, "%d", &a[i]);
- fclose(fp);
-
- for(i = 0; i < N; i++)
- cout << a[i] << endl;
- }
-
- int main()
- {
- write();
- read();
-
- return 0;
- }
从控制台上可以看到,上面两个程序的结果是完全相同的. 为了更好地理解二进制文件和文本文件的区别,可以比较下面三项: (此处不给出比较结果. 不理解时,运行程序,自己比较一下,印象更深刻.)
1. myData和yourData两个文件的大小;
2. 用记事本方式(或文本方式)打开myData和yourData, 看是否出现乱码.
3. 用UltraEdit打开myData和yourData,对比一下结果.
最后,通过一个极为简单的例子来看UltraEdit读取二进制文件时的显示规律, 程序为:
- #include<iostream>
- #define N 8
- using namespace std;
-
- void write()
- {
- int i, a[N];
- for(i = 0; i < N; i++)
- {
- a[i] = i - N/2;
- cout << a[i] << "\t";
- }
- cout << endl;
-
- FILE *fp;
- fp = fopen("myData", "wb");
- fwrite(a, sizeof(a), 1, fp);
- fclose(fp);
- }
-
- int main()
- {
- write();
- return 0;
- }
控制台上的结果为: -4 -3 -2 -1 0 1 2 3
(-4的补码是FFFFFFFC)
用UltraEdit打开myData, 结果如下:
FC FF FF FFFD FF FF FF FE FF FF FF FF FF FF FF
00 00 00 00 01 00 00 00 02 00 00 00 03 00 00 00
可见,这些刚好是控制台上结果对应的补码(注意补码的高低位顺序).
既然讲到了fscanf函数,下面来介绍一个用fscanf函数读取文件中所有整数的方法:
- #include<iostream>
- using namespace std;
-
- int main()
- {
- FILE *fp = fopen("myData.txt", "w");
- fprintf(fp, "1 2 \n3 4 5 6 \n"); // \n为换行
- fclose(fp);
-
- int a;
- fp = fopen("myData.txt", "r");
- while(EOF != fscanf(fp, "%d", &a))
- cout << a << endl; // 读取文件中所有的整数
- fclose(fp);
-
- return 0;
- }