南通图片高清:printf函数调用时进栈的顺序
来源:百度文库 编辑:偶看新闻 时间:2024/04/30 02:53:00
printf函数调用时进栈的顺序
正文
转自: http://youxiren2.my.gsdn.net/2004/11/11/3698/
————————————–(1)———————————-
# include
main()
{
int i=1;
printf(”%d %d %d”, i , i++, i++);
}
进栈顺序:
1. i=1;算最后一个i++,i=2;将加之前i的值1送入堆栈。
2. i=2;算倒数第二个i++,i=3;将加之前i的值2送入堆栈。
3. i=3;计算i,i=3;将加之前i的值3送入堆栈。
输出结果为(出栈顺序):3 2 1
————————————–(2)———————————-
# include
main()
{
int i=1;
printf(”%d %d %d”, i , ++i, ++i);
}
进栈顺序:
1. i=1;算最后一个++i,i=2;将加之后i的值2送入堆栈。
2. i=2;算倒数第二个++i,i=3;将加之后i的值3送入堆栈。
3. i=3;计算i,i=3;将加之后i的值3送入堆栈。
输出结果为(出栈顺序):3 3 2
————————————–(3)———————————-
# include
main()
{
int i, j, k; i=1; j=2; k=3;
printf(”%d %d %d”, i , j, k);
}
进栈顺序:
1. k=3;算k,k=3;将k的值3送入堆栈。
2. j=2;算j,j=2;将j的值2送入堆栈。
3. i=1;计算i,i=1;将i的值1送入堆栈。
输出结果为(出栈顺序):1 2 3