a++问题&深入

  • ​​​​​a++的汇编形式

一下都是在DEV C++环境下进行的

汇编名词说明(需要一定计组功底),同类寄存器都可以看做是一个寄存器

a++问题&深入

 

C语言源代码

a++问题&深入

汇编源码分析:

a++问题&深入

 

  • 多重++/--的汇编形式

C语言源代码

a++问题&深入

汇编源码分析:

a++问题&深入

同上面的一样一顿操作之后结果就出来了,如下:

a++问题&深入

总结出一个规律:在DEV  C++环境下,当连续输出一个变量的++/--时,从右到左依次计算,将后缀的正常运算值直接写在位置上,当关于变量的所有运算完毕之后,将最终值填充到前缀位置上。

 

++,--问题到此结束,以下是输出系统调用输出寄存器顺序的测试:

不过有一个问题,系统调用的输出顺序是什么样的?

而后又做了如下测试:

C语言源代码:

a++问题&深入

纯输出,尝试推测系统调用的输出顺序(寄存器)

a++问题&深入

上图说明,在没有计算的理想情况下,a,c,co,d,addr_high.......addr_low(eax,ecx,通用寄存器,edx,主存高位地址......主存低位地址)是他的输出顺序。

下面来看之前的代码

a++问题&深入

图中已经存在计算干扰了,受到影响的寄存器有哪些?

首先从后往前看a,a的顺序正常,值为11;

再来看c,ecx的内容在最后一次传送到了主存(基址+偏移量),同时8拥有了这个数据,c的顺序失效;

再来看8,发现他还是正常的(没有将内容传送到其他地方),8的顺序正常,值为12;

再来看9,正常,值为9;

再来看d,正常,值为12;

所以结果是11,12,9,12。

 

欢迎在下方讨论!