• OpenEuler中C语言中的函数调用测试


    C语言中的函数调用

    32位GCC中的运行时堆栈使用情况

    • main.c:
    main(){
    int a,b,c;
    a=1;b=2;c=3;
    c=sub(a,b);
    printf("c=%d\n",c);
    }
    
    • sub.c
    int sub(int x,int y){
            int u,v;
            u=4;v=5;
            return x+y+u+v;
    }
    

    • 使用gcc -g main.c sub.c -o main -m32指令在64位的机器上产生32位汇编,然后使用gdb main指令进入gdb调试器:
    • 进入之后先在main函数处设置一个断点,再run一下,使用disassemble指令获取汇编代码,用i(info) r(registers)指令查看各寄存器的值:

      看到这一步的时候u,v被压入栈中

      所以u,v栈的地址为

    longjump

    include<stdio.h>
    #include<setjmp.h>
    jmp_buf env;
    
    int main()
    {
            int r,a=100;
            printf("call setjmp to save environmen\n");
            if((r=setjmp(env))==0){
                    A();
                    printf("normal return\n");
            }
            else
                    printf("back to main() via long jump,r=%d,a=%d",r,a);
    }
    
    int A()
    {
            printf("enter A()\n");
            B();
            printf("exit A()\n");
    
    }
    
    int B()
    {
            printf("enter B()\n");
            printf("long jump?(y|n) ");
            if(getchar()=='y')
                    longjmp(env,1234);
            printf("exit B()\n");
    }
    

    64位GCC中的运行时堆栈使用情况

    #include <stdio.h>
    int sub(int a, int b, int c, int d, int e, int f, int g, int h)
    {
    int u, v, w;
    u = 9;
    v = 10;
    w= 11;
    return a+g+u+v;
    }
    
    int main()
    {
    int a, b, c, d, e,f, g, h,i;
    a = 1;
    b = 2;
    c = 3;
    d = 4;
    e = 5;
    f = 6;
    g = 7;
    h = 8;
    i = sub(a,b,c,d,e,f,g,h);
    }
    
    • 在64位Linux中,编译t.c生成64位汇编的t.s文件:

      然后,编辑t.s文件,删除编译器生成的非必要行,并添加注释来解释代码操作。下面给出了带有添加的注释行的简化t.s文件。

    openeuler环境下只能运行64位.C代码

  • 相关阅读:
    linux使用命令记录
    (转)如何连接远程桌面
    PLSQL将查询结果复制为insert语句
    用foxPro打开dbf文件
    (转)PLSQL新手使用教程
    CPN TOOL使用
    运行mongoDB
    PLSQL连接数据库
    剑指 Offer 10- II. 青蛙跳台阶问题(简单)
    剑指 Offer 10- I. 斐波那契数列(简单)
  • 原文地址:https://www.cnblogs.com/1301cn/p/15634370.html
Copyright © 2020-2023  润新知