请问这段反汇编每句的含义,谢谢

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了请问这段反汇编每句的含义,谢谢相关的知识,希望对你有一定的参考价值。

push %ebp
mov %esp,&ebp
sub $0x18,%esp
and $0xfffffff0,%esp
mov $0x0,%eax
sub %eax,%esp
sub $0x8,%esp
push $0x8049480
lea offffffe8(%ebp),%eax
push %eax
call ox804829c<strcpy>
add $0x10,%esp
leave
ret

参考技术A 大概给你解释一下:
push %ebp ///保护ebp
mov %esp,&ebp
sub $0x18,%esp //分配18个字节的空间
and $0xfffffff0,%esp //0xfffffff0和esp寄存器中的值做与运算
mov $0x0,%eax //eax=0x0
sub %eax,%esp
sub $0x8,%esp
push $0x8049480 //0x8049480入栈,这应该是一个内存地址,你可以去这个地址看一下内容
lea offffffe8(%ebp),%eax //eax寄存器里的值做为地址,将这个地址的值给ebp,这句代码是一个指针运算
push %eax //压入eax
call ox804829c<strcpy> //call库函数strcpy
add $0x10,%esp
leave
ret //返回

这段代码完成了一个字符串拷贝的功能,在C语言里的表现形式应该如下:
strcpy(char *,const char *);
具体的字符串内容需要通过动态调试来取得本回答被提问者采纳

解释一下,下面一段程序,每句代码的含义,以及输出结果。

#include <stdio.h>
int main( )
int p1;
while((p1=fork())==-1);
if(p1==0)
printf(“I am child 1\n”); //子进程
else
//父进程 printf(“I am parent\n”);
return 0;

参考技术A #include <stdio.h>
int main( )
int p1; //定义变量 p1
while((p1=fork())==-1); // 执行p1 = fork(), 并判断 p1 是否等于-1:如果不等于-1,继续执行 p1 = fork();
// fork 是LINUX 下的函数,作用是将当前进程的变量,数据复制一份到另一个进程执行。如果fork成功,返回进程的id,否则返回-1
//fork调用的一个奇妙之处就是它仅仅被调用一次,却能够返回两次,它可能有三种不同的返回值:
//1)在父进程中,fork返回新创建子进程的进程ID;
// 2)在子进程中,fork返回0;
// 3)如果出现错误,fork返回一个负值;

if(p1==0) //如果 p1 等于 0,说明是子进程
printf(“I am child 1\n”); //子进程
else //如果p1不等于0 ,说明是父进程
//父进程 printf(“I am parent\n”);
return 0;追问

对应每一句,怎么判断p1的值啊?

追答

while((p1=fork())==-1); 这条语句相当于:

p1 = fork(); // fork 执行成功,p1 >=0 ( 子进程中返回0,父进行返回进程ID),失败返回-1

while( p1 == -1 ) // 看是否fork失败(判断子进程是否成功创建,==-1表示未成功)
p1 = fork(); // 未成功则继续fork

关于FORK的功能看上面的解释

本回答被提问者和网友采纳
参考技术B #include <stdio.h>
main()

int a,b,z;
printf(“请输入两个整数:”);
scanf(“%d,%d”,&a,&b);
z=maxnum(a,b);
line();
printf(“较大的数据为:%20d”,z);
line();
.
Int maxnum(int x,int y)

Int z;
z=x>y?x:y;
Return(z);

Line()

Printf(“*************************************************”);

以上是关于请问这段反汇编每句的含义,谢谢的主要内容,如果未能解决你的问题,请参考以下文章

初步的看一下C#窗体程序的直接反汇编代码

汇编的问题

请解释下面delphi代码每句的含义

汇编指令中冒号(:)的未知含义

反汇编系列——堆栈篇

反编译和反汇编有啥区别?