#include <stdio.h>
int main (){
int i = 1;
printf("%d-->%d-->%d-->%d",i++,i++,i++,i++);
printf("最终的i == %d",i);
return 0;
}
//输出结果:
//4-->3-->2-->1最终的i == 5
/*
printf的声明
int _cdecl printf(const char* format, …);
_cdecl是C和C++程序的缺省调用方式
_CDEDL调用约定:
1.参数从右到左依次入栈
2.调用者负责清理堆栈
3.参数的数量类型不会导致编译阶段的错误
int main(){
printf("%lf--%lf--%lf",1.0/0.0,0.0/0.0,1/0.0);
//double的0.0实际上并不是所有位都是0,而是一个非常小的小数因此结果是无限小.
//结果为:1.#INF00---1.#IND00--1.#INF00
}
int main (){
int i = 1;
printf("%d-->%d-->%d-->%d",i++,i++,i++,i++);
printf("最终的i == %d",i);
return 0;
}
//输出结果:
//4-->3-->2-->1最终的i == 5
/*
printf的声明
int _cdecl printf(const char* format, …);
_cdecl是C和C++程序的缺省调用方式
_CDEDL调用约定:
1.参数从右到左依次入栈
2.调用者负责清理堆栈
3.参数的数量类型不会导致编译阶段的错误
对于x86而言,栈向下生长,函数参数从右向左入栈,因此从第一个固定参数(format)
地址向前(向上)移动就可得到其他变参的地址。*/
int main(){
printf("%lf--%lf--%lf",1.0/0.0,0.0/0.0,1/0.0);
//double的0.0实际上并不是所有位都是0,而是一个非常小的小数因此结果是无限小.
//结果为:1.#INF00---1.#IND00--1.#INF00
}