1、
#include <stdio.h> int main(void) { FILE *fp; // 定义指向FILE型的指针变量 double pi = 3.14159265358979323846; printf("Pi from value: %23.21f. ", pi); // 直接输出变量pi的值,不等于原始变量, 这是因为浮点数的精度是有限的 //利用fwrite函数将变量pi的值写入到二进制文件中。 if((fp = fopen("PI.bin", "wb")) == NULL) // 以只写入的方式打开文件PI.bin. printf("aFile open failed. "); else { fwrite(&pi, sizeof(double), 1, fp);// 利用fwrite函数将变量pi的值写入到流fp中(文件PI.bin)中 fclose(fp); } //利用fread函数读取二进制文件PI.bin的值,保存至变量中,并进行显示 if((fp = fopen("PI.bin", "rb")) == NULL)// 以只读方式打开PI.bin printf("aFile open failed. "); else { fread(&pi, sizeof(double), 1, fp); // 利用fread函数读取fp流中的数据,并保存至变量pi printf("Pi from file: %23.21f. ", pi); // 显示pi的值, 此时显示的pi的值和直接显示的pi变量的值是一致的,这说明变量在保存和输出过程中没有发生 //任何变化(在浮点数可以显示的精度范围内) fclose(fp); } return 0; } // 以上程序说明了什么? 以二进制的方式保存变量的值,可以保存所有的位数
#include <stdio.h> int main(void) { FILE *fp; //声明指向FILE型的指针变量 double pi = 3.14159265358979323846; printf("pi from value: %23.21f. ", pi); //直接输出变量的值,与原始变量不一致,这是因为浮点数的精度有限 //利用fwrite函数将变量pi的值写入到二进制文件PI.bin中。 if((fp = fopen("PI.bin", "wb")) == NULL) // 以只写的方式打开文件 printf("aFile open failed. "); else { fwrite(&pi, sizeof(double), 1, fp);//利用fwrite函数将变量pi的值写入到fp流(二进制文件PI.bin中) fclose(fp); } //利用fread函数读取二进制文件PI.bin中的值,保存至变量并进行显示 if((fp = fopen("PI.bin", "rb")) == NULL) //以只读的方式打开二进制文件 printf("aFile open failed. "); else { fread(&pi, sizeof(double), 1, fp); //利用fread函数读取fp流的数值,并保存至变量pi中 printf("pi from file: %23.21f. ", pi); // 输出pi的值, 和程序开头直接输出变量的值一致,说明将实数保存在二进制文件中,可以保存所有的位 fclose(fp); } return 0; }