C语言写的程序 怎么反汇编成汇编语言

C语言写的程序 怎么反汇编成汇编语言,第1张

如果你手上没有什么第三方工知具的话,可以用DEBUG,

比如你用C写了一腔困搏个程序1.exe

生成的位置是d:\1.exe

打开电脑左下角开始--->运行--->输入双引号里面道伍祥的"cmd"--->确定

d出一个黑色窗体,在上面输入输入双引号里面尺滑的"debug

d:\1.exe"

然后回车

接着会出现一个"-"符号

然后输入"u"

回车

就可回以看到相应的汇编了,这只是一个简单的例子,有兴趣可以学下DEBUG用法,要是大工程的话,还是建立答用别的工具,

注意:这只是在windows平台下用,像linux等别的平台不知道有没有.

gcc编译雹宴的程序码是没有“Intel”、“at&t”之分的⋯⋯就是二进制而已。所谓的“Intel”、“at&t”是指汇编语言的写作格式。

如果你用yum软件包管理器,sudo yum install nasm。

如果你用apt-get,sudo apt-get install nasm。

如果不行,就到sourceforge下载nasm的rpm(如果是yum)或deb(apt-get),然后安装。

如果还不行,下载源码,然后终端里(在解压出的目录下):

./configure

make

sudo make install

最后,ndisasm -b 32 文件名。

顺便一说安装的这个nasm是intel格式的汇派肆晌编编译器。相当好。然后ndisasm是它附尘锋带的反汇编器。

不好意思没法放网址。百度会把这个回答给删掉。

star特530的是ARM汇编的。

这个问题很复杂。这得看你的二进制程序是否包含这些信息。这得看 编译选皮中项 有没有包含 -s 。-s选项会剔除不需要的符号名。

正式二进制发布的软件是可以没有这些信息的。对于静态链接后 函数名在c/c++ 语言执行的过程中是不需要的,它是通过内存地址 去访问 内存,数据和代码。函数名用于 编译过程 和链接过程。对于动太链接在程序执行过程由ld.so 通过变量名去 动态的链接到某些库的指定函数。动态链接的符号名不可剔除。

说到底就是二进制程序如果包含变量名,就会显示。

实例

main.c:

int aaa=10

int myfunc(){

    return 5

}

int main(){

    int bbb=20

    aaa=20

    bbb=myfunc()

    return 0

} gcc -nostdlib main.c -o main_with_symbols

gcc -nostdlib main.c -o main_without_symbols

分别产生包含符号名 和不包含符号名的 可执行文件。

!122 ~/src/c_cpp % objdump -d main_with_symbols|grep myfunc

000000000040017c <myfunc>:

  胡握好4001a5:   裤铅 e8 d2 ff ff ff           callq  40017c <myfunc>

!123 ~/src/c_cpp % objdump -d main_without_symbols|grep myfunc

!124 ~/src/c_cpp 1 %

很明显使用 -s 选项后 很多符号信息丢失,反汇编中也不包含相关符号名。


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/yw/12334622.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-05-22
下一篇2023-05-22

发表评论

登录后才能评论

评论列表(0条)

    保存