打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
C语言中的printf(" %d\n %d\n %d\n %d\n %d\n %d\n",++i,--i,i++,i--,-i++,-i--)
 

#include<stdio.h>
void main()
{
 int i=8;
 printf(" %d\n %d\n %d\n %d\n %d\n %d\n",++i,--i,i++,i--,-i++,-i--);
}

#include<stdio.h>
void main()
{
 int i=8;
 printf("%d\n",++i);
 printf("%d\n",--i);
 printf("%d\n",i++);
 printf("%d\n",i--);
 printf("%d\n",-i++);
 printf("%d\n",-i--);
}

两者的区别
像这种问题应该与编译器有关,在vc环境下的结果是8788-8-8因为,在vc下,printf函数中,右自增自减是无法实现的,也就是等于没有,可以看看反汇编的代码0040D78F   mov         eax,dword ptr [ebp-4]0040D792   neg         eax0040D794   mov         dword ptr [ebp-8],eax0040D797   mov         ecx,dword ptr [ebp-8]0040D79A   push        ecx这是最后一个参数的反汇编,因为在C语言中,参数的调用,是从右到左的参数压入堆栈,所以先压入的是最后一个I,由于用了负号,所以,最后一个是-8,从右到左第二个一样,也用了负号,所以也是-8依此第三个,没有加负号,所以是8,再依次,还是8,最后两个,也就是从左到右第一二个,从右到左第5 ,6个,开始有变化了,我可以给你反汇编的代码看看,他们是左自增(自减),也就是先自增再使用,所以从右到左第5个,是7,是由于它自减,你可以看看反汇编代码0040D7BB   mov         edx,dword ptr [ebp-4]0040D7BE   sub         edx,10040D7C1   mov         dword ptr [ebp-4],edx0040D7C4   mov         eax,dword ptr [ebp-4]0040D7C7   push        eax可以看到,先是把i的值给了寄存器值是8,再减-1就是7了,再把值赋值给i,那个,[ebp-4]就是i的地址,压入堆栈的时候是7,再看看最后压入堆栈的,0040D7C8   mov         ecx,dword ptr [ebp-4]0040D7CB   add         ecx,10040D7CE   mov         dword ptr [ebp-4],ecx0040D7D1   mov         edx,dword ptr [ebp-4]0040D7D4   push        edx开始,[ebp-4]由于开始已经是7了,所以,add 加1后,就是8了,再把8给,[ebp-4]所以,最后i的值还是8,压入堆栈的时候,edx是8,所以,依此排列下来,压入的顺序就是,-8-88878最后堆栈的特点你应该了解吧,先入的后出,也就是,从下面开始调出,最后,就是8788-8-8看C看不懂的时候, 可以反汇编看下。
本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
献给汇编初学者-函数调用堆栈变化分析
C语言自增自减运算符深入剖析
C++虚函数表与对象布局(转)
数组的实现机制
小细节大问题——程序的效率 - winnie的专栏 - CSDN博客
DLL中调用约定和名称修饰(一)
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服