gpt4 book ai didi

c++ - FStream 读取用 Delphi 的二进制编写器编写的二进制文件

转载 作者:塔克拉玛干 更新时间:2023-11-03 01:47:15 27 4
gpt4 key购买 nike

我正在 MS Visual Studio 2010 Express 中创建一个 dll,它使用 C++ 中的 fstream 库加载二进制数据文件(*.mgr 扩展名 -> 专门用于我公司的应用程序)。该文件是使用我公司中使用 Delphi 的其他人开发的应用程序创建的。他说前 15 个字节应该是一些指示文件创建日期的字符和一些其他内容,例如应用程序的版本:

“XXXX 2012”。

用fstream(二进制方式)加载后,用fstream(字符串方式)写入另一个文件后的结果如下:

[] X X X X 2 0 1 2"

第一个字符是未知字符(矩形),然后每个字符之间有空格。最后它是 31 字节宽。 15 个实际字符 + 15 个空格 + 1 个矩形字符 = 31。

一些其他信息:我正在使用 C++,应用程序开发人员正在使用 Delphi。我正在使用 fstream。他正在使用 BW.Write() 函数。 (BW == 二进制编写器?)他使用 Windows 7,而我使用 Windows XP Professional。

你能诊断出问题吗?

提前致谢

第一次编辑:我正在添加加载那些第一个字节的 C++ 代码。

首先,他使用的是来自 embarcadero Rad Studio XE2 的 Delphi XE2。

据我所知,PChar 是一个以 null 结尾的字符串,由 widechars(自 delphi 2009 起)组成,与普通字符(一个字节)相比,宽字符为 2 个字节。所以基本上他是在保存单词而不是字节。

这是加载管理器的代码:

wchar_t header[15];
DXFLIBRARY_API void loadMGR(const char* szFileName, const char* szOutput)
{
fstream file;
file.open( szFileName, ios::binary | ios::in );
if(file.is_open())
{
file.read(reinterpret_cast<char*>(header),sizeof(header));
}
file.close();

//zapis

fstream saveFile;
saveFile.open( szOutput, ios::out );
if(saveFile.is_open())
{
saveFile.write(reinterpret_cast<const char*>(header),sizeof(header));
}
saveFile.close();
}

header 包含 15 个 wchar_t,所以我们得到 30 个字节。在调查之后我仍然不知道如何转换。

最佳答案

很明显,数据在 8 位文本编码和 16 位编码之间被破坏。伪造的第一个字符几乎可以肯定是 UTF-16 BOM。

一种可能的解释是,Delphi 开发人员正在将 UTF-16 编码文本写入文件。并且大概您期望 8 位编码。

另一种解释是 Delphi 代码正确地写出 8 位文本,但您的代码正在破坏它。也许您的读/写代码正在这样做。

对 Delphi 程序的文件输出使用十六进制编辑器,以准确缩小发生错位的范围。

在问题中没有任何代码的情况下,很难比这更具体。

关于c++ - FStream 读取用 Delphi 的二进制编写器编写的二进制文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12956967/

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