Closed. This question is off-topic。它当前不接受答案。
想改善这个问题吗? Update the question,所以它是on-topic,用于堆栈溢出。
3年前关闭。
是否有Linux / Unix工具可用于将C文件的十六进制转储数组(即
假定存储在文件
在许多方面,重新生成原始代码的最简单方法是:
稍加注意,再加上一些宏,就可以使该程序成为通用的大纲程序-您需要提供文件名和要使用的两个C变量名。
如果您不能(或不想)使用C编译器来完成这项工作,那么使用Python或Perl编写工具是简单明了的练习。例如,一个不一定最小的Perl脚本是:
它使用“自动拆分”选项(
想改善这个问题吗? Update the question,所以它是on-topic,用于堆栈溢出。
3年前关闭。
是否有Linux / Unix工具可用于将C文件的十六进制转储数组(即
xxd -i
的输出)转换为相应的源代码? 最佳答案
源文件xxd -i xyz.c
的xyz.c
输出如下:
unsigned char xyz_c[] = {
0x23, 0x69, 0x6e, 0x63, 0x6c, 0x75, 0x64, 0x65, 0x20, 0x3c, 0x73, 0x74,
0x64, 0x69, 0x6f, 0x2e, 0x68, 0x3e, 0x0a, 0x23, 0x69, 0x6e, 0x63, 0x6c,
0x75, 0x64, 0x65, 0x20, 0x3c, 0x73, 0x74, 0x64, 0x6c, 0x69, 0x62, 0x2e,
0x68, 0x3e, 0x0a, 0x23, 0x69, 0x6e, 0x63, 0x6c, 0x75, 0x64, 0x65, 0x20,
0x3c, 0x73, 0x74, 0x72, 0x69, 0x6e, 0x67, 0x2e, 0x68, 0x3e, 0x0a, 0x0a,
…
0x65, 0x5f, 0x6c, 0x69, 0x73, 0x74, 0x28, 0x73, 0x74, 0x61, 0x72, 0x74,
0x29, 0x3b, 0x0a, 0x20, 0x20, 0x20, 0x20, 0x7d, 0x0a, 0x0a, 0x20, 0x20,
0x20, 0x20, 0x72, 0x65, 0x74, 0x75, 0x72, 0x6e, 0x20, 0x30, 0x3b, 0x0a,
0x7d, 0x0a
};
unsigned int xyz_c_len = 4442;
假定存储在文件
xyz.xxd
中。在许多方面,重新生成原始代码的最简单方法是:
#include <stdio.h>
#include "xyz.xxd"
int main(void)
{
for (unsigned int i = 0; i < xyz_c_len; i++)
putchar(xyz_c[i]);
return 0;
}
稍加注意,再加上一些宏,就可以使该程序成为通用的大纲程序-您需要提供文件名和要使用的两个C变量名。
如果您不能(或不想)使用C编译器来完成这项工作,那么使用Python或Perl编写工具是简单明了的练习。例如,一个不一定最小的Perl脚本是:
#!/usr/bin/env perl -na
use strict;
use warnings;
# xxd -i drops the final comma - aargh (why?)!
foreach my $word (@F)
{
next unless $word =~ m/^0[Xx][[:xdigit:]]{2},?$/;
$word =~ s/,//;
printf "%c", hex($word);
}
它使用“自动拆分”选项(
-a
)和“自动读取但不打印”选项(-n
),然后处理输入中看起来像十六进制字符的任何单词,例如0x0a(可选后跟一个逗号,因为xxd -i
会在最后一个字节值之后不必要地省略逗号),并将其转换为相应的字节。这是Perl,TMTOWTDI —做到这一点的方法不止一种。关于c++ - 将“xxd -i”编码的C源代码转换为C源代码的脚本/工具? ,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/35974932/
10-11 22:51