gpt4 book ai didi

c++ - 自定义二进制文件在 C++ 中触发 failbit

转载 作者:行者123 更新时间:2023-11-27 23:38:18 26 4
gpt4 key购买 nike

<分区>

tl;dr:自定义文件必须具有哪些必要的控制字符才能触发 [或触发] badbit、failbit、badbit、eofbit 取决于操作系统?


我正在使用 Cygwin 和 Notepad++,在 x64 笔记本电脑上使用 Windows 7。

我有一个名为 genesis.o 的文件,我在与 sandbox.cpp 相同的目录中的十六进制编辑器中键入了该文件 我正在从中进行阅读/写作。文件“genesis.o”包含:

genesis.o 
-----------------
58 - 4f - 58 - 4f
58 - 58 - 58 - 58
3f - 3f - 3f - 3f
00 - 00 - 00 - 3f
00 - 00 - 3f - 00
00 - 3f - 00 - 00
3f - 00 - 00 - 00
00 - 00 - 00 - 58
00 - 00 - 58 - 00
00 - 58 - 00 - 00
58 - 00 - 00 - 00
48 - 45 - 4c - 4c

到目前为止,我已经读取和操作了自定义结构,而没有考虑文件的有效性。我使用 stat 检查文件是否可访问,这就足够了。

这个文件(带和不带扩展名“.o”)通过了我所做的所有检查,除了 file.rdstate 它总是返回 4 (std::ios::failbit).

错误不会在任何其他普通文件中显示出来,所以我猜测文件之前/之后或文件中的某种控制字符序列实际上告诉 std::fstream 该文件是有效的.

由于没有其他文件(在十六进制编辑器中键入的文件除外)触发此行为,是否有一种方法可以构造一个自定义二进制文件以供 fstream 识别?某种控制字符、预设标志等?

我正在使用 std::ios:in | std::ios:二进制。我通过获取 stat buffer.st_size 来读取它 -> 将它除以 4(因为我读取了 4 字节整数)并且:

uitn32_t temp = 0;
file.read( (char *)(&temp), sizeof(uint32_t) );

值得注意的是,即使 file.rdstate 返回 failbit,我也可以读取该二进制文件。

最小的可测试示例。只需制作一个具有上述字符规范的“genesis.o”文件即可。

#include <fstream>
#include <iostream>
#include <string>

#include <sys\types.h>
#include <sys\stat.h>
#include <vector>

struct handl{
std::string name = "genesis";
std::string ext = "o";
std::vector<uint32_t> mem;
bool acces = false;
struct stat buffer;

handl():mem(0),name("genesis"),ext("o"){}

const char *f_name(){
std::string f_n = this->name;
f_n.append(".");
f_n.append(this->ext);
return f_n.c_str();
}

void recheck(){
this->acces = ( stat(this->f_name(), &this->buffer ) == 0 );
}

virtual bool header( std::fstream &file )
{return true;}
virtual bool footer( std::fstream &file )
{return true;}

void operator()(){ this->recheck(); }
void operator()( const char *name, const char *ext ){
this->name = std::string(name);
this->ext = std::string(ext);
this->recheck();
}

void prefix( const char* pre ){
std::string pn(pre);
pn.append( this->name );
this->name = pn;
}

void suffix( const char *su ){
this->name.append(su);
this->recheck();
}

int read(){

this->recheck();
if( !this->acces ){return 0;}

std::fstream file;
file = std::fstream( this->f_name(), std::ios::in | std::ios::binary );

if( this->header(file) && this->footer(file) ){

int byte_size = this->buffer.st_size;

std::cout << file.rdstate() << std::endl;
std::cout << "gb\t" << std::ios::goodbit << std::endl;
std::cout << "bb\t" << std::ios::badbit << std::endl;
std::cout << "eb\t" << std::ios::eofbit << std::endl;
std::cout << "fb\t" << std::ios::failbit << std::endl;

file.close();
return 1;
}else{
file.close();
return 0;
}

}

};

int main(){

handl f;

std::cout << f.read() << std::endl;

return 0;
}

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com