[C语言](*p)++ 与 *p++ 与 ++*p 拨开一团迷雾
2024-08-29 03:24:13
环境:win7
IDE:DEV-C++
编译器:GCC
1.先说++i和i++的基础
代码如下:
#include <stdio.h> //just change simple
void stop(void)
{
system("pause");
} int main(void)
{
int i = 1;
printf("i++ = %d\n",i++);
printf("i = %d\n",i); int j = 1;
printf("++j = %d\n",++j);
printf("j = %d\n",j); printf("i++ = : %d ++i = %d\n",i++,++i);
printf("i = %d\n",i);
printf("++j = : %d j++ = %d\n",++j,j++);
printf("j = %d\n",j);
stop();
return 0;
}
运行结果:
i++ =
i =
++j =
j =
i++ = : ++i =
i =
++j = : j++ =
j =
1)i++只有遇到";"分号才会影响i的值, i++输出的值还是1,i的值也是1
2)i经过分号之后,i=2,因为自增了
3)++j不管遇到不遇到分号";"都会影响j值和++j值,所以J=2
4)j的值也是2
5)根据编译器的不同和操作系统的不同,printf计算方向也不同,这是从右开始计算,先++i,再i++,所以输出3 和3
6)最后一个i++遇到了分号,所以i=4
7)从右开始计算,j打印的结果还是2,但是第二次取出来的值是3,所以++j=4
2.理清概念 *p++ 中 *和++的优先级
#include <stdio.h> //just change simple
void stop(void)
{
system("pause");
} int main(void)
{
int i = ;
int *p;
p = &i;
printf("1-p = %d\n",p);
int v;
v = *p++;
printf("v = %d\n",v);
printf("2-p = %d\n",p);
printf("i = %d\n",i);
system("pause");
return ;
}
运行结果:
-p =
v =
-p =
i =
从结果来看++符号影响了p的值并没有影响i的值,好像++的优先级要高于 指针*符号
再看例子
#include <stdio.h> //just change simple
void stop(void)
{
system("pause");
} int main(void)
{
int i = ;
int *p;
p = &i;
printf("1-p = %d\n",p);
int v;
v = ++*p;
printf("v = %d\n",v);
printf("2-p = %d\n",p);
printf("i = %d\n",i);
system("pause");
return ;
}
运算结果:
-p =
v =
-p =
i =
怎么++不影响p的值了?
再看例子
把 代码稍微调整:v = *++p;
运算结果:
-p =
v =
-p =
i =
啊额,原来 * 和++优先级是同一级别,同一级别按照从右往左的顺序计算。
OK了,渐渐的所有问题都解决了,
*(p++)
*(++p)
(*p)++
++(*p)应该没有问题了
迷雾终于拨开了。。。
最新文章
- 编译可在Android上运行的qemu user mode
- php命名空间和autoload
- Architecture.the-reactive-manifesto
- MSClass 和setInterval 的并发,ajax定时有采集信息滚动显示
- Oracle存储过程执行update语句不报错不生效问题
- location.pathname;outline:medium;undefined不能加引号
- mysql的interval函数用法
- WINCE6.0 error C2220: warning treated as error问题解决
- phpstorm显示行号
- 《Java从入门到放弃》JavaSE入门篇:异常
- CentOS文件权限管理
- C# 插入文本框到PPT幻灯片
- Android OS 源码 引入和编译 jar / so库
- python--多线程多进程
- 【PS技巧】如何拼图
- 深入解析内存原理:RAM的基本原理
- java 传入list集合 返回树形菜单,for循环遍历
- python语法(三)— 循环
- Awk 从入门到放弃(5)– Awk模式(Pattern)之一
- visibility和display