【C 语言】文件操作 ( 使用 fseek 函数生成指定大小文件 | 偏移量 文件字节数 - 1 )

简介: 【C 语言】文件操作 ( 使用 fseek 函数生成指定大小文件 | 偏移量 文件字节数 - 1 )

文章目录

一、fseek 函数生成指定大小的文件





一、fseek 函数生成指定大小的文件


利用 fseek 函数可以移动指针的原理 , 文件打开后 , 直接调用 fseek 函数 , 将指针向后移动指定偏移 , 然后在偏移后的位置写出一个字节数据 , 可以瞬间生成一个指定大小的文件 ;


如要生成 n nn 字节的文件 , 可以先将指针指向距离开始位置偏移 n nn 字节的位置 , 在此处写出一个空字节 , 即可精准的生成一个 n nn 字节的文件 ;



fseek 函数原型 :


#include <stdio.h>
int fseek(FILE *stream, long offset, int fromwhere);


fseek 函数的作用是 以 int fromwhere 参数为基准 , 偏移 long offset 个字节 , 该偏移可以是正数 , 也可以是负数 ;



这里特别注意 , 如果要精准的生成 100 字节大小的文件 , 需要从开始位置偏移 99 字节 , 然后指针指向第 100 字节的位置 , 此时写入一个字节 , 写入的这个字节就是第 100 字节数据 , 其前面 99 个字节都是空的 ;



生成 1000 * 1000 字节大小的文件 ;


特别注意 : 将指针指向 距离开始位置 1000 * 1000 - 1 字节偏移位置 , 在第 1000 * 1000 字节处 , 写入一个字节数据 ;



代码示例 :


#include <stdio.h>
int main()
{
    // 以写文本的方式向文件中写出数据
    FILE *p = fopen("D:/File/1000.dat", "w");
    // 将指针指向 距离开始位置 1000 * 1000 - 1 字节偏移位置
    // 这里特别注意 , 要预留出一个字节 , 用于做数据填充
    fseek(p, 1000 * 1000 - 1, SEEK_SET);
    // 在文件内部指针指向的第 1000 * 1000 字节处 , 写入一个字节数据
    char a = 0;
    fwrite(&a, 1, sizeof(a), p);
    // 关闭文件
    fclose(p);
    return 0;
}


执行结果 :


目录
相关文章
|
4月前
|
存储 程序员 C语言
c语言文件操作
本文介绍了C语言中文件操作的核心概念,包括文件缓冲区、数据与程序文件的区别、流的概念及标准输入输出流。重点讲解了文件的打开与关闭、读写操作(如fgetc、fputs、fscanf、fwrite等),以及随机读写函数fseek、ftell和rewind的使用方法。同时说明了文本文件与二进制文件的读取结束判定方式,并通过代码示例展示了实际应用。
|
5月前
|
存储 C语言
`scanf`是C语言中用于按格式读取标准输入的函数
`scanf`是C语言中用于按格式读取标准输入的函数,通过格式字符串解析输入并存入指定变量。需注意输入格式严格匹配,并建议检查返回值以确保读取成功,提升程序健壮性。
1120 0
|
7月前
|
安全 C语言
C语言中的字符、字符串及内存操作函数详细讲解
通过这些函数的正确使用,可以有效管理字符串和内存操作,它们是C语言编程中不可或缺的工具。
362 15
|
8月前
|
存储 编译器 程序员
c语言的文件操作与文件缓冲区
如果没有文件,我们写的程序的数据是存储在电脑的内存中,如果程序退出,内存回收,数据就丢失了,等再次运行程序,是看不到上次程序的数据的,如果要将数据进行持久化的保存,我们可以使用文件。磁盘(硬盘)上的文件是文件。但是在程序设计中,我们⼀般谈的⽂件有两种:程序文件、数据文件(从文件功能的角度来分类 的)。就比如说我们电脑中以.txt为后缀的就是文件的一种,他就是数据文件。.exe为后缀的就为程序文件。函数名功能适用范围fgetc字符输入函数所有输入流fputc字符输出函数所有输出流fgets。
197 0
|
12月前
|
人工智能 Java 程序员
一文彻底搞清楚C语言的函数
本文介绍C语言函数:函数是程序模块化的工具,由函数头和函数体组成,涵盖定义、调用、参数传递及声明等内容。值传递确保实参不受影响,函数声明增强代码可读性。君志所向,一往无前!
504 1
一文彻底搞清楚C语言的函数
|
12月前
|
人工智能 C语言
|
存储 编译器 C语言
【C语言程序设计——函数】分数数列求和2(头歌实践教学平台习题)【合集】
函数首部:按照 C 语言语法,函数的定义首部表明这是一个自定义函数,函数名为fun,它接收一个整型参数n,用于指定要求阶乘的那个数,并且函数的返回值类型为float(在实际中如果阶乘结果数值较大,用float可能会有精度损失,也可以考虑使用double等更合适的数据类型,这里以float为例)。例如:// 函数体代码将放在这里函数体内部变量定义:在函数体中,首先需要定义一些变量来辅助完成阶乘的计算。比如需要定义一个变量(通常为float或double类型,这里假设用float。
582 3
|
存储 C语言
C语言 文件操作 深度解析 #重点知识:文件操作函数的使用#(下)
C语言 文件操作 深度解析 #重点知识:文件操作函数的使用#(下)
|
Linux 编译器 C语言
C语言 文件操作 深度解析 #重点知识:文件操作函数的使用#(上)
C语言 文件操作 深度解析 #重点知识:文件操作函数的使用#(上)