我试图从包含纯文本标题和二进制图像信息的图像文件中删除标题。作为此的先驱,我希望将文件信息复制到一个字符串中进行编辑。在执行此操作时,我遇到了一些问题,导致我尝试简单地读取文件,并将其作为一个新文件重新写入,以便进行调试。当我这样做时,新文件最终比原来的文件大约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();
....谢谢你的帮助!-David
发布于 2013-09-25 18:48:53
试试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();
}https://stackoverflow.com/questions/19012830
复制相似问题