如何实现一个函数,用于将整数数组写入文件,并从文件中读取整数数组

下面我将提供一个简单的C语言示例,展示了如何实现一个函数将整数数组写入文件,以及另一个函数从文件中读取整数数组。为了简化,我们将假设整数数组的长度是已知的,并且在写入文件之前已经定义好了。

写入整数数组到文件

复制代码

c复制代码

|---|------------------------------------------------------------------------------------|
| | #include <stdio.h> |
| | #include <stdlib.h> |
| | |
| | // 写入整数数组到文件 |
| | void writeIntArrayToFile(const int* array, size_t size, const char* filename) { |
| | FILE* file = fopen(filename, "wb"); // 以二进制写入模式打开文件 |
| | if (file == NULL) { |
| | perror("打开文件失败"); |
| | exit(EXIT_FAILURE); |
| | } |
| | |
| | // 写入数组的大小(可选,用于读取时知道要读取多少元素) |
| | fwrite(&size, sizeof(size_t), 1, file); |
| | |
| | // 写入数组内容 |
| | fwrite(array, sizeof(int), size, file); |
| | |
| | fclose(file); |
| | } |
| | |
| | ### 读取整数数组从文件 |
| | |
| | c ```` | | | `// 从文件中读取整数数组 ` | | | `int* readIntArrayFromFile(const char* filename, size_t* size) { ` | | | `FILE* file = fopen(filename, "rb"); // 以二进制读取模式打开文件 ` | | | `if (file == NULL) { ` | | | `perror("打开文件失败"); ` | | | `return NULL; ` | | | `} ` | | | | | | `// 读取数组的大小 ` | | | `if (fread(size, sizeof(size_t), 1, file) != 1) { ` | | | `perror("读取数组大小失败"); ` | | | `fclose(file); ` | | | `return NULL; ` | | | `} ` | | | | | | `// 分配内存来存储数组 ` | | | `int* array = (int*)malloc(*size * sizeof(int)); ` | | | `if (array == NULL) { ` | | | `perror("内存分配失败"); ` | | | `fclose(file); ` | | | `return NULL; ` | | | `} ` | | | | | | `// 读取数组内容 ` | | | `if (fread(array, sizeof(int), *size, file) != *size) { ` | | | `perror("读取数组内容失败"); ` | | | `free(array); ` | | | `fclose(file); ` | | | `return NULL; ` | | | `} ` | | | | | | `fclose(file); ` | | | `return array; ` | | | `} ` | | | | | | `### 示例用法 ` | | | | | | c ```` |
| | int main() { |
| | // 示例整数数组 |
| | int numbers[] = {1, 2, 3, 4, 5}; |
| | size_t size = sizeof(numbers) / sizeof(numbers[0]); |
| | |
| | // 写入数组到文件 |
| | writeIntArrayToFile(numbers, size, "numbers.bin"); |
| | |
| | // 从文件读取数组 |
| | size_t readSize; |
| | int* readNumbers = readIntArrayFromFile("numbers.bin", &readSize); |
| | if (readNumbers != NULL) { |
| | // 输出读取的数组内容 |
| | for (size_t i = 0; i < readSize; ++i) { |
| | printf("%d ", readNumbers[i]); |
| | } |
| | printf("\n"); |
| | |
| | // 释放分配的内存 |
| | free(readNumbers); |
| | } |
| | |
| | return 0; |
| | } |

注意:在这个示例中,我们使用了二进制模式("wb""rb")来打开文件,这样可以确保整数以它们在内存中的原始格式写入和读取,而不受文本模式可能引入的换行符转换等问题的影响。另外,我们还写入了数组的大小到文件中,这样读取时就能知道要读取多少元素。在读取完成后,我们使用 free 函数释放了动态分配的内存。

相关推荐
yvestine4 分钟前
自然语言处理——文本表示
人工智能·python·算法·自然语言处理·文本表示
慢半拍iii21 分钟前
数据结构——F/图
c语言·开发语言·数据结构·c++
GalaxyPokemon33 分钟前
LeetCode - 148. 排序链表
linux·算法·leetcode
iceslime1 小时前
旅行商问题(TSP)的 C++ 动态规划解法教学攻略
数据结构·c++·算法·算法设计与分析
aichitang20242 小时前
矩阵详解:从基础概念到实际应用
线性代数·算法·矩阵
OpenCSG2 小时前
电子行业AI赋能软件开发经典案例——某金融软件公司
人工智能·算法·金融·开源
witton3 小时前
美化显示LLDB调试的数据结构
数据结构·python·lldb·美化·debugger·mupdf·pretty printer
chao_7893 小时前
链表题解——环形链表 II【LeetCode】
数据结构·leetcode·链表
dfsj660113 小时前
LLMs 系列科普文(14)
人工智能·深度学习·算法
薛定谔的算法4 小时前
《盗梦空间》与JavaScript中的递归
算法