C语言读写二进制文件
fseek用法
fseek用来移动文件指针。函数原型
int fseek(FILE * stream, long offset, int fromwhere);
参数解释:
- stream 是文件流指针
- offset 是相对文件起始位置的偏移量
- fromwhere移动到哪儿。 其值如下
- SEEK_SET:从距文件开头 offset 位移量为新的读写位置;
- SEEK_CUR:以目前的读写位置往后增加 offset 个位移量;
- SEEK_END:将读写位置指向文件尾后再增加 offset 个位移量。
例如:
将读写位置移动到文件开头:fseek(fp, 0, SEEK_SET);
将读写位置移动到文件尾时:fseek(fp, 0, SEEK_END);
将读写位置动到离文件开头100字节处:fseek(fp,100L, SEEK_SET);
将读写指针移动到离文件当前位置100字节处:fseek(fp,100L, SEEK_CUR);
将读写指针退回到离文件结尾100字节处:fseek(fp, -100L, SEEK_END);
准备代码
准备一个下面的结构体,用作演示
struct st_type_no_item_
{
/// 类型
int type_ = 0;
/// 编号
int no_ = 0;
st_type_no_item_()
{
type_ = 0;
no_ = 0;
}
};
///
using st_type_no_item = st_type_no_item_;
写二进制文件
使用函数fwrite实现写入,演示使用,当然,你可以加上函数的返回值,表示写入文件的结果
void write_file_(std::string str)
{
FILE *pfile = nullptr;
int ret = fopen_s(&pfile, str.c_str(), "wb");
/// 0 = 打开成功,
if (0 == ret)
{
if (pfile)
{
/// 准备内存
st_type_no_item item;
item.type_ = 0x22;
item.no_ = 0x33;
int len = sizeof(st_type_no_item);
/// 写文件
int write_length = fwrite(&item, sizeof(st_type_no_item), 1, pfile);
fclose(pfile);
pfile = nullptr;
std::cout << "\n 写文件成功, 写入长度=" << write_length << "\n";
}
else
{
;/// pfile 文件指针为null
std::cout << "\n 写文件失败, pfile = null \n\n";
}
}
else
{
;/// 打开失败
std::cout << "\n 写文件失败,文件打开失败\n\n";
}
}
读二进制文件
使用函数fread读取二进制文件。 需要注意fread函数的参数。 应该检查其返回值于函数的第三个参数是否相等,如果不相等,则读取失败。 相等则读取成功
/// ----------------------------------------------------------------------------------------
/// 读文件
void read_file_(std::string str)
{
FILE *pfile = nullptr;
int ret = fopen_s(&pfile, str.c_str(), "rb");
/// 0 = 打开成功,
if (0 == ret)
{
if (pfile)
{
fseek(pfile, 0, SEEK_END);
unsigned int file_length_bytes = ftell(pfile);
fseek(pfile, 0, SEEK_SET);
if (0 < file_length_bytes)
{
/// 准备内存
st_type_no_item item;
char arr[8] = { 0 };
/// 读文件.参数依次是: 文件读取缓存、缓存的类型基本长度、需要读取多少个单位的缓存、文件流
/// 这里演示: item是缓存, sizeof(st_type_no_item)表示item的长度, 1表示读取一个单位的item(8字节),pfile是文件流
/// fread成功,将返回 第三个参数相同的值,说明读取成功,其他失败。
int readlen = fread(&item, sizeof(st_type_no_item), 1, pfile);
std::cout << "\n 读文件成功, type=" << item.type_ << ", no=" << item.no_ << "\n\n";
}
else
{
;/// 文件长度为0
}
/// 关闭文件
fclose(pfile);
pfile = nullptr;
}
else
{
;/// pfile 文件指针为null
std::cout << "\n 读文件失败, pfile = null \n\n";
}
}
else
{
;/// 打开失败
std::cout << "\n 读文件失败,文件打开失败\n\n";
}
}
结果

完整演示代码
#include <iostream>
/// 判断文件是否存在
bool is_exist_file_(std::string&& str_file)
{
struct stat st;
return (0 == stat(str_file.c_str(), &st));
}
struct st_type_no_item_
{
int type_ = 0;
int no_ = 0;
st_type_no_item_()
{
type_ = 0;
no_ = 0;
}
};
///
using st_type_no_item = st_type_no_item_;
/// ----------------------------------------------------------------------------------------
/// 写文件
void write_file_(std::string str)
{
FILE *pfile = nullptr;
int ret = fopen_s(&pfile, str.c_str(), "wb");
/// 0 = 打开成功,
if (0 == ret)
{
if (pfile)
{
/// 准备内存
st_type_no_item item;
item.type_ = 0x22;
item.no_ = 0x33;
int len = sizeof(st_type_no_item);
/// 写文件
int write_length = fwrite(&item, sizeof(st_type_no_item), 1, pfile);
fclose(pfile);
pfile = nullptr;
std::cout << "\n 写文件成功, 写入长度=" << write_length << "\n";
}
else
{
;/// pfile 文件指针为null
std::cout << "\n 写文件失败, pfile = null \n\n";
}
}
else
{
;/// 打开失败
std::cout << "\n 写文件失败,文件打开失败\n\n";
}
}
/// ----------------------------------------------------------------------------------------
/// 读文件
void read_file_(std::string str)
{
FILE *pfile = nullptr;
int ret = fopen_s(&pfile, str.c_str(), "rb");
/// 0 = 打开成功,
if (0 == ret)
{
if (pfile)
{
fseek(pfile, 0, SEEK_END);
unsigned int file_length_bytes = ftell(pfile);
fseek(pfile, 0, SEEK_SET);
if (0 < file_length_bytes)
{
/// 准备内存
st_type_no_item item;
char arr[8] = { 0 };
/// 读文件.参数依次是: 文件读取缓存、缓存的类型基本长度、需要读取多少个单位的缓存、文件流
/// 这里演示: item是缓存, sizeof(st_type_no_item)表示item的长度, 1表示读取一个单位的item(8字节),pfile是文件流
/// fread成功,将返回 第三个参数相同的值,说明读取成功,其他失败。
int readlen = fread(&item, sizeof(st_type_no_item), 1, pfile);
std::cout << "\n 读文件成功, type=" << item.type_ << ", no=" << item.no_ << "\n\n";
}
else
{
;/// 文件长度为0
}
/// 关闭文件
fclose(pfile);
pfile = nullptr;
}
else
{
;/// pfile 文件指针为null
std::cout << "\n 读文件失败, pfile = null \n\n";
}
}
else
{
;/// 打开失败
std::cout << "\n 读文件失败,文件打开失败\n\n";
}
}
/// ----------------------------------------------------------------------------------------
int main()
{
std::string str = "C:\\game\\demo.txt";
bool is_exist = true;// is_exist_file_(std::move(str));
if (!is_exist)
return 0;
/// 写文件
write_file_(str);
read_file_(str);
std::cout << is_exist << "\n\n\n";
}
fread_s读取文件
下面的完整代码演示了使用函数fread_s读取二进制文件
#include <iostream>
/// 判断文件是否存在
bool is_exist_file_(std::string&& str_file)
{
struct stat st;
return (0 == stat(str_file.c_str(), &st));
}
struct st_type_no_item_
{
int type_ = 0;
int no_ = 0;
st_type_no_item_()
{
type_ = 0;
no_ = 0;
}
};
///
using st_type_no_item = st_type_no_item_;
/// ----------------------------------------------------------------------------------------
/// 写文件
void write_file_(std::string str)
{
FILE *pfile = nullptr;
int ret = fopen_s(&pfile, str.c_str(), "wb");
/// 0 = 打开成功,
if (0 == ret)
{
if (pfile)
{
/// 准备内存
st_type_no_item item[2];
item[0].type_ = 0x1;
item[0].no_ = 0x1;
item[1].type_ = 0x2;
item[1].no_ = 0x2;
int len = sizeof(st_type_no_item);
/// 写文件
int write_result = fwrite(item, sizeof(st_type_no_item), 2, pfile);
if (write_result != 2)
{
std::cout << "write error , ret=" << write_result << "\n";
}
else
{
std::cout << "write success, ret=" << write_result << "\n";
}
fclose(pfile);
pfile = nullptr;
}
else
{
;/// pfile 文件指针为null
std::cout << "\n 写文件失败, pfile = null \n\n";
}
}
else
{
;/// 打开失败
std::cout << "\n 写文件失败,文件打开失败\n\n";
}
}
/// ----------------------------------------------------------------------------------------
/// 读文件
void read_file_(std::string str)
{
FILE *pfile = nullptr;
int ret = fopen_s(&pfile, str.c_str(), "rb");
/// 0 = 打开成功,
if (0 == ret)
{
if (pfile)
{
fseek(pfile, 0, SEEK_END);
unsigned int file_length_bytes = ftell(pfile);
fseek(pfile, 0, SEEK_SET);
if (0 < file_length_bytes)
{
/// 准备内存
st_type_no_item item[2];
/// 读文件.参数依次是: 文件读取缓存、缓存的类型基本长度、需要读取多少个单位的缓存、文件流
/// 这里演示: item是缓存, sizeof(st_type_no_item)表示item的长度, 1表示读取一个单位的item(8字节),pfile是文件流
/// fread成功,将返回 第三个参数相同的值,说明读取成功,其他失败。
//int readlen = fread(&item, sizeof(st_type_no_item), 1, pfile);
int ret = fread_s(item, sizeof(st_type_no_item) * 2, sizeof(st_type_no_item), 2, pfile);
std::cout << "ret=" << ret << "\n";
std::cout << "type0=" << item[0].type_ << ", no0=" << item[0].no_ << "\n";
std::cout << "type1=" << item[1].type_ << ", no1=" << item[1].no_ << "\n";
//std::cout << "\n 读文件成功, type=" << item.type_ << ", no=" << item.no_ << "\n\n";
}
else
{
;/// 文件长度为0
}
/// 关闭文件
fclose(pfile);
pfile = nullptr;
}
else
{
;/// pfile 文件指针为null
std::cout << "\n 读文件失败, pfile = null \n\n";
}
}
else
{
;/// 打开失败
std::cout << "\n 读文件失败,文件打开失败\n\n";
}
}
/// ----------------------------------------------------------------------------------------
int main()
{
std::string str = "C:\\game\\demo.txt";
bool is_exist = true;// is_exist_file_(std::move(str));
if (!is_exist)
return 0;
/// 写文件
write_file_(str);
read_file_(str);
std::cout << is_exist << "\n\n\n";
}
C语言读写二进制文件的更多相关文章
- [Matlab+C/C++] 读写二进制文件
introduction 因为Matlab操作简单.方便,它被应用于很多领域:音频处理,图像处理,数值计算等.尽管MATLAB容易操作,但受限于他的语言解释机制,MATLAB的执行速度通常较低.C/C ...
- R语言读写中文编码方式
最近遇到一个很头疼的事,就是 R语言读写中文编码方式.在网上找到了一篇博文,谢谢博主的精彩分享,让我很快解决了问题,在此也分享一下 R语言读写数据的方法很多,这里主要是我在使用read.csv/rea ...
- 【转】C++读写二进制文件
原文网址:http://blog.csdn.net/lightlater/article/details/6364931 摘要: 使用C++读写二进制文件,在开发中操作的比较频繁,今天有幸找到一篇文章 ...
- C/C++读写二进制文件
C++读写二进制文件 最近在给android层提供支持,因此代码都是用标准库库函数写出来的,好多windows和第三方的库不能或者很难使用,下面有我在读写二进制文件时候的一些心得,也算是一种总结吧 1 ...
- R语言读写数据
R语言读写数据 一般做模型的时候,从外部的excel中读入数据,我现在常用的比较多的是read_csv(file) 读入之前先把excel数据转化成.csv格式 同样的把结果输出来的时候用的是writ ...
- C++封装C语言读写文件
自己项目需要,封装C语言读写文件. 为了兼容低版本的编译器,因为低版本的编译器(比如,Vs2010,Vs2008)他们可能不支持 modern c++. 项目 使用 cmake管理的项目. 可以在 g ...
- C语言读写文件
对文件的读和写是最常用的文件操作.在C语言中提供了多种文件读写的函数: 字符读写函数 :fgetc和fputc 字符串读写函数:fgets和fputs 数据块读写函数:freed和fwrite 格式 ...
- c++读写二进制文件
要读取文件必须包含<fstream>头文件,这里包含了C++读写文件的方法,可以使用fstream 类,这个类可以对文件进行读写操作. 1.打开文件. 打开文件可以有两种方式,第一 ...
- Java读写二进制文件示例
相对于文本文件,二进制文件读写快,定位快而准,下面是代码示例: import java.io.DataInput; import java.io.DataOutput; import java.io. ...
随机推荐
- Synteny和collinear的区别
在比较基因组学的时候,经常会听到"共线性"这个词,但是与其对应的有两个不同的概念,即 (1) synteny (2) collinear 二者的区别如下图所示: 可以看到,synt ...
- requests+bs4爬取豌豆荚排行榜及下载排行榜app
爬取排行榜应用信息 爬取豌豆荚排行榜app信息 - app_detail_url - 应用详情页url - app_image_url - 应用图片url - app_name - 应用名称 - ap ...
- Excel—在Excel中利用宏定义实现MD5对字符串(如:手机号)或者文件加密
下载宏文件[md5宏] 加载宏 试验md5加密 可能遇到的问题 解决办法 下载宏文件[md5宏] 下载附件,解压,得md5宏.xla md5宏.zip 加载宏 依次打开[文件]-[选项]-[自定义功能 ...
- 框架学习-MyBatis(01)
1.MyBatis是持久层框架 什么是持久化: 狭义:把数据永久性的保存到数据当中 广义:针对于数据库的所有操作都称为持久化操作,CreateReadUpdateDelete操作 2.有哪些持久层框架 ...
- MybatisPlus的CRUD及拓展
创建一个简单的MybatisPlus项目在上一篇博客:MybatisPlus入门程序 一.CRUD 1. select 1.1 查找全部用户 //查 @Test public void select( ...
- ArrayList总结及部分源码分析
ArrayList源码阅读笔记 1. ArrayList继承的抽象类和实现的接口 ArrayList类实现的接口 List接口:里面定义了List集合的基本接口,ArrayList进行了实现 Rand ...
- 外网无法访问hdfs文件系统
由于本地测试和服务器不在一个局域网,安装的hadoop配置文件是以内网ip作为机器间通信的ip. 在这种情况下,我们能够访问到namenode机器, namenode会给我们数据所在机器的ip地址供我 ...
- Vue 之keep-alive的使用,实现页面缓存
什么是keep-alive 有时候我们不希望组件被重新渲染影响使用体验: 或者处于性能考虑,避免多次重复渲染降低性能.而是希望组件可以缓存下来,维持当前的状态.这时候就需要用到keep-alive组件 ...
- Oracle中的instr函数
最近修改某个条件,由原来输入一个数据修改为可以输入多个,如图所示: 在实现时用到了regexp_substr函数进行分割连接起来的数据,查询时还用到了instr函数进行判断,但出现了问题,当子库存输入 ...
- Java设计模式—Proxy动态代理模式
代理:设计模式 代理是一种常用的设计模式,其目的就是为其他对象提供一个代理以控制对某个对象的访问.代理类负责为委托类预处理消息,过滤消息并转发消息,以及进行消息被委托类执行后的后续处理. 图 1. 代 ...