局部变量和全局变量的执行效率问题

定义

局部变量:指在函数内部声明的变量

全局变量:指在所有函数外部定义的变量

测试

int a=0;//全局变量
int function()
{
    int b=0;//局部变量

    a++;
    b++;

    printf("%d %d\r\n",a,b);

    return 0;
}

在keil5中的针对Cortex-M3内核的汇编如下:

a为全局变量,a++ 执行了5条指令

LDR      r0,[pc,#24]    执行了加载全局变量a的地址到通用寄存器R0

LDR      r0,[r0,#0x00]     加载R0地址的数据到R0

ADDS     r0,r0,#1        R0数值加1

LDR      r1,[pc,#20]     加载a的地址到R1

STR      r0,[r1,#0x00]  将R0的数据写到R1+0为地址的存储器中

b为局部变量,b++ 执行1条指令

MOVS     r4,#0x00 初始化局部变量b=0;

ADDS     r4,r4,#1 局部变量b加1

此处 b被分配到了寄存器变量R4中,执行效率会很高,但如果有出入栈的局部变量另当别论。

很早之前写的,以免误导大家,特此说明。


版权声明:本文为ai5945fei原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。