本文主要是介绍C语言的(++a) + (++a) + (++a)反汇编代码分析,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
@[TOC](C语言的(++a) + (++a) + (++a)反汇编代码分析)
1、看问题现象
我们先来看一段c语言的代码,虽然说我们有运算符的结合性,但是这段代码在不同的编译器下的执行结果也是不一样的
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
int main()
{int a = 1;int b = (++a) + (++a) + (++a);printf("%d\n", b);return 0;
}
在本地的Visual Studio C++来执行的结果如下:
同clion我们执行的结果如下
2、分析Visual Studio C++上该代码反汇编的过程
2.1、Visual Studio开启反汇编
出现如下图所示代表成功
接下来我们需要做一些操作,让他完全是一种反汇编的样子
2.2、反汇编分析
指令 | 含义 |
---|---|
ebp | 通常代表的是一个地址 |
esp | 通常代表的是一个地址 |
eax | 寄存器 |
ebx | 寄存器 |
ecx | 寄存器 |
edx | 寄存器 |
// 下面的图是分析的这行代码
int a = 1;
一次++a就会发生下面两张图的情况
我们同上面的道理再次往下运行,发现都先计算的是++a,于是就又计算了两次++a,结果如下
以上就是Visual Studio C++进行反编译的过程,有问题欢迎指正
这篇关于C语言的(++a) + (++a) + (++a)反汇编代码分析的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!