我有一组二进制配置文件,每个文件有三个版本 - 每个文件的原始版本和两个不同修改版本。我需要能够同时看到两个版本和原版本之间的差异。
我需要的是二进制文件的三向差异工具。通过相当耗费精力的谷歌搜索,我最终发现了一个应用程序的屏幕截图,它正是我所需要的 - 不幸的是,包含该图像的论坛帖子没有提到他们正在使用的应用程序:
http://www.xboxhacker.org/index.php?topic=15032.0
有人能指出我(Windows)应用程序的方向,提供三个二进制文件的二进制安全(十六进制)比较吗?
答案 0 :(得分:9)
Vim有一个内置的差异工具,可以比较任意数量的文件。它也可以在Windows上运行。您可以在http://vim.org找到它。
vim for windows的标准安装包括xxd
,它允许您将二进制文件视为文本:
例如,如果您尝试:
xxd xxd.exe
你会得到:
0000000: 4d5a 9000 0300 0000 0400 0000 ffff 0000 MZ..............
0000010: b800 0000 0000 0000 4000 0000 0000 0000 ........@.......
0000020: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0000030: 0000 0000 0000 0000 0000 0000 d800 0000 ................
0000040: 0e1f ba0e 00b4 09cd 21b8 014c cd21 5468 ........!..L.!Th
0000050: 6973 2070 726f 6772 616d 2063 616e 6e6f is program canno
0000060: 7420 6265 2072 756e 2069 6e20 444f 5320 t be run in DOS
0000070: 6d6f 6465 2e0d 0d0a 2400 0000 0000 0000 mode....$.......
0000080: 6ba7 bec3 2fc6 d090 2fc6 d090 2fc6 d090 k.../.../.../...
等...
因此,您可以使用xxd
将二进制文件转储到文本文件中:
xxd orig > orig.txt
xxd mod1 > mod1.txt
xxd mod2 > mod2.txt
然后在diff模式下运行vim:
vim -d orig mod1 mod2
这会给你这样的东西:
(此屏幕截图取自here,仅仅是对VIM中三向差异的说明)
所有这些工具都可以在Windows中使用,因此它们可以解决您的问题。
修改强>
合并xxd
的结果后,可以使用xxd -r
将十六进制转储转换为二进制文件:
xxd -r merged_xxd_file merged_binary_file
您可以在xxd
's manpage
答案 1 :(得分:2)
屏幕截图来自Araxis Merge。他们的专业版(270美元)支持三方比较。
答案 2 :(得分:1)
您可以查看ECMerge(我正在使用的工具),它有2和3路差异的二进制文件(HEX + ASCII)。没有合并功能。您可以轻松地从更改区域移动到更改区域并压缩长区域(长插入,更改或更改)。
答案 3 :(得分:0)
最新版本的 Beyond Compare 似乎支持3-way diff and merge。此外,它的feature list表示它支持二进制文件的比较。
请注意,这不是免费软件: - )
答案 4 :(得分:0)
我最近被介绍给p4merge,它似乎也支持二进制文件。
它需要3个文件作为输入:原始和两个衍生物。它并排显示它们,第四个窗口显示合并文件,具有编辑功能和冲突解决方案。
我只是用它来合并一个大型代码库的两个分支,这非常方便。
现在,我还没有使用它来合并二进制文件,但它确实支持区分图片,所以如果不支持二进制文件,我会感到惊讶。