3

我试图从包含纯文本标题和二进制图像信息的图像文件中剥离标题。作为对此的先驱,我想将文件信息复制到字符串流中进行编辑。这样做时,我遇到了一些问题,这些问题导致我尝试简单地读取文件并将其作为新文件再次写回以进行调试。当我这样做时,新文件最终比原始文件大 1kb。在 UltraEdit 中进行二进制比较时,似乎在任何出现 HEX 字符 0A(我相信换行)的地方,我的程序似乎都在它之前添加了 0D(回车)。我想知道这种行为的原因是什么以及如果可能的话如何避免它。代码片段如下:

....
std::string inputFilename = argv[1];
std::ifstream in( argv[1],ios::out | ios::binary);
if ( in )
{
std::stringstream fileStream;
fileStream<<in.rdbuf();
cout<<fileStream.str().length(); //debugging
in.close();
ofstream myfile;
myfile.open("selfoutput");
myfile<<fileStream.str();
myfile.close();
....

谢谢你的帮助!-大卫

4

1 回答 1

2

尝试ios:in

std::ifstream in( argv[1],ios::in | ios::binary)

或者,事实上

std::ifstream in( argv[1],ios::binary)

这是等效的:

首先,执行与默认构造函数相同的步骤,然后通过调用rdbuf()->open(filename, mode | std::ios_base::in). 将流与文件相关联。如果 open() 调用返回空指针,则设置 setstate(failbit)

这是我的(未经测试的)最简单的看法:

#include <fstream>

int main(int /*argc*/, const char *argv[])
{
    std::ifstream in(argv[1], std::ios::binary);
    if (in)
    {
        std::ofstream myfile("selfoutput", std::ios::binary);
        if (myfile)
            myfile << in.rdbuf();
    }
}

为了免费的代码高尔夫和不良风格:

#include <fstream>
using namespace std;

int main(int /*argc*/, const char *argv[]) {
    ofstream("selfoutput", ios::binary) << ifstream(argv[1], ios::binary).rdbuf();
}
于 2013-09-25T18:48:53.717 回答