zoukankan      html  css  js  c++  java
  • 2019-2020-1 20199316《Linux内核原理与分析》第二周作业

    计算机是如何工作的

    反编一个C程序

    实验过程

    • 首先在shell环境下查看目录以及编译main.c文件

    • main.c代码如下:

    
    // main.c
    int g(int x)
    {
        return x + 3;
    }
    
    int f(int x)
    {
        return g(x);
    }
    
    int main(void)
    {
        return f(8) + 1;
    }
    
    
    • 接着,在平台上输入下面一行代码进行反编
    
    gcc -s -o main.s main.c -m32
    
    
    • 然后,当我满心欢喜的打开反编文件时- -

    • 这是什么东西?这不是我想要的代码啊!你们走错片场了吧......

    • 言归正传,待我检查出自己的小错误,终于无伤大雅的把反编代码给搞出来了,真心不容易- -

    实验分析

    - pushl %ebp,将ebp寄存器的值进行压栈。接着将esp寄存器指向的地址减4,即向下移动一位。 - movl %esp,%ebp,将esp所指的位置赋值给ebp。 - subl $4,%esp,esp寄存器减4,并且eip的值加一。 - movl $8,(%esp),将8放入到esp所指向的位置。 - call f,把eip的值先压倒栈顶,再将函数f的第一条指令pusjl %ebp位置放到eip中。 - pushl %ebp(意思同上) - 这里我就把重复的指令省略啦 ![](https://img2018.cnblogs.com/blog/1801303/201909/1801303-20190922160710800-719932065.jpg) - leave,撤销函数main的堆栈。 - ret,ebp和esp变回初始状态。
  • 相关阅读:
    delete误删除恢复
    oracle自增字段
    oracle唯一约束
    linux得到系统当前日期
    to_char+fm
    oracle范围分区
    oracle之use_hash用法
    oracle11g的regexp函数
    第一个脚本输入参数
    使用ctl将txt或csv文件导入表数据
  • 原文地址:https://www.cnblogs.com/destiny-love/p/11567621.html
Copyright © 2011-2022 走看看