请问这段反汇编每句的含义,谢谢
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
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;
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的功能看上面的解释
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(“*************************************************”);
以上是关于请问这段反汇编每句的含义,谢谢的主要内容,如果未能解决你的问题,请参考以下文章