c语言操作空间怎么打开_第十一讲:C语言基础之文件操作

本文约4900字,主要讲C文件概述、文件的分类、ASCII文件和二进制文件的比较、C语言对文件的处理方法、文件的打开与关闭、文件的打开(fopen函数)、文件的关闭(fclose函数)等。

带你进入C语言的世界,入门C语言,后边将持续更新。可以收藏学习。想了解共用体、枚举类型、用typedef定义类型等,请点击该处跳转阅读。

本文全干货,新手必备,感谢你的阅读,祝你学有所成,生活愉快!


一、C文件概述

所谓“文件”是指一组相关数据的有序集合。这个数据集有一个名称,叫做文件名。实际上在前面的各章中我们已经多次使用了文件,例如源程序文件、目标文件、可执行文件、库文件 (头文件)等。

文件通常是驻留在外部介质(如磁盘等)上的,在使用时才调入内存中来。从不同的角度可对文件作不同的分类。从用户的角度看,文件可分为普通文件和设备文件两种。

操作系统是以文件为单位对数据进行管理的。

7a53fbf02ac747092184846494ef4a40.png

二、文件的分类

1.从用户观点:

特殊文件(标准输入输出文件或标准设备文件)

普通文件(磁盘文件)

2.从操作系统的角度看,每一个与主机相连的输入、输出设备看作是一个文件。

例:输入文件:终端键盘

输出文件:显示屏和打印机

3.按数据的组织形式:

ASCII文件(文本文件):每一个字节放一个ASCII代码

二进制文件:把内存中的数据按其在内存中的存储形式原样输出到磁盘上存放。

例如整数10000D在内存中的存储形式以及分别按ASCII码形式和二进制形式输出如下图所示:

70156ea140c0ce12e3387d7bf8402f29.png

三、ASCII文件和二进制文件的比较

1.ASCII文件便于对字符进行逐个处理,也便于输出字符。但一般占存储空间较多,而且要花费转换时间。

2.二进制文件可以节省外存空间和转换时间,但一个字节并不对应一个字符,不能直接输出字符形式。

3.一般中间结果数据需要暂时保存在外存上,以后又需要输入内存的,常用二进制文件保存。

四、C语言对文件的处理方法

1.缓冲文件系统:系统自动地在内存区为每一个正在使用的文件开辟一个缓冲区。用缓冲文件系统进行的输入输出又称为高级磁盘输入输出。

2.非缓冲文件系统:系统不自动开辟确定大小的缓冲区,而由程序为每个文件设定缓冲区。用非缓冲文件系统进行的输入输出又称为低级输入输出系统。

五、补充知识

在UNIX系统下,用缓冲文件系统来处理文本文件,用非缓冲文件系统来处理二进制文件。ANSI C 标准只采用缓冲文件系统来处理文本文件和二进制文件。C语言中对文件的读写都是用库函数来实现。

六、文件的打开与关闭

文件型指针变量:FILE *fp;

fp是一个指向FILE类型结构体的指针变量。

我们使fp指向某一个文件的结构体变量,从而通过该结构体变量中的文件信息能够访问该文件。如果有n个文件,一般应设n个指针变量,使它们分别指向n个文件,以实现对文件的访问。

FILE类型的数组:

FILE f[5]; 定义了一个结构体数组f,它有5个元素,可以用来存放5个文件的信息。

七、文件的打开(fopen函数)

函数调用:

  • FILE *fp;
  • fp = fopen(文件名,使用文件方式);

注意:

需要打开的文件名,也就是准备访问的文件的名字

使用文件的方式(“读”还是“写”等);

让哪一个指针变量指向被打开的文件。

八、文件使用方式

文件使用方式      含   义

“r” (只读)为输入打开一个文本文件

“w” (只写)为输出打开一个文本文件

“a” (追加)向文本文件尾增加数据

“rb” (只读)为输入打开一个二进制文件

“wb” (只写)为输出打开一个二进制文件

"ab“ (追加)向二进制文件尾增加数据

"r+“ (读写)为读/写打开一个文本文件

"w+” (读写)为读/写建立一个新的文本文件

"a+” (读写)为读/写打开一个文本文件

"rb+“ (读写)为读/写打开一个二进制文件

“wb+“ (读写)为读/写建立一个新的二进制文件

“ab+” (读写)为读/写打开一个二进制文件

对于文件使用方式有以下几点说明:

1.凡用“r”打开一个文件时,该文件必须已经存在,且只能从该文件读出。

2.用“w”打开的文件只能向该文件写入。若打开的文件不存在,则以指定的文件名建立该文件,若打开的文件已经存在,则将该文件删去,重建一个新文件。

3.若要向一个已存在的文件追加新的信息,只能用“a”方式打开文件。但此时该文件必须是存在的,否则将会出错。

4.在打开一个文件时,如果出错,fopen将返回一个空指针值NULL。

5.在程序中可以用这一信息来判别是否完成打开文件的工作,并作相应的处理。

6.把一个文本文件读入内存时,要将ASCII码转换成二进制码,而把文件以文本方式写入磁盘时,也要把二进制码转换成ASCII码,因此文本文件的读写要花费较多的转换时间。对二进制文件的读写不存在这种转换。

九、文件的关闭(fclose函数)

函数调用:fclose(文件指针);

函数功能:

使文件指针变量不指向该文件,也就是文件指针变量与文件“脱钩”,此后不能再通过该指针对原来与其相联系的文件进行读写操作。

返回值:关闭成功返回值为0;否则返回EOF(-1)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是直接插入排序的完整C语言代码: ```c #include <stdio.h> void insertion_sort(int arr[], int n) { int i, j, key; for (i = 1; i < n; i++) { key = arr[i]; j = i - 1; while (j >= 0 && arr[j] > key) { arr[j + 1] = arr[j]; j = j - 1; } arr[j + 1] = key; } } int main() { int arr[] = {64, 25, 12, 22, 11}; int n = sizeof(arr) / sizeof(arr[0]); insertion_sort(arr, n); printf("Sorted array: "); for (int i = 0; i < n; i++) { printf("%d ", arr[i]); } printf("\n"); return 0; } ``` 该程序使用了一个名为`insertion_sort`的函数来执行直接插入排序。在`main`函数中,我们定义了一个整数数组`arr`,包含了一些未排序的数字。我们使用`sizeof`操作符计算数组的大小,然后将其作为参数传递给`insertion_sort`函数。 `insertion_sort`函数首先定义了三个整数变量`i`,`j`和`key`。`i`用于遍历数组中的元素,`j`用于向前扫描已排序的子数组,`key`用于存储当前要插入的元素。在排序过程中,我们从数组的第二个元素开始循环,将当前元素存储在`key`变量中,并将`j`初始化为当前元素的前一个位置。 然后,我们开始向前扫描已排序的子数组,如果当前元素比`key`大,则将已排序的子数组中的元素向右移动一个位置,为当前元素腾出空间。当已排序的子数组中的元素小于或等于`key`时,我们将`key`插入到已排序的子数组中的正确位置。 最后,我们在`main`函数中输出已排序的数组。 实验步骤: 1. 打开C语言编译器,创建一个新的源代码文件。 2. 复制上述代码并将其粘贴到新文件中。 3. 编译并运行程序,查看排序后的结果。 设计思路: 直接插入排序算法的基本思想是将未排序的元素插入到已排序的子数组中,从而得到一个逐步增长的已排序数组。该算法的时间复杂度为O(n²),适用于小规模数据排序。在该程序中,我们使用一个名为`insertion_sort`的函数来执行直接插入排序。该函数使用两个循环来遍历数组中的元素,并将当前元素插入到已排序的子数组中的正确位置。最后,我们在`main`函数中输出已排序的数组。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值