c语言指针p+1与p++有什么不同 5
12个回答
展开全部
第一句应该是p = p+1吧。
这2句的结果是一样的,相信楼主也是知道的,都表示p+1然后结果存储在p中。
但是所有的研发还是实验,如果碰到自加1的运算都会选择p++,这里面的关键点是p++的运算速度比p=p+1快,虽然一条语句说快能块多少呢?但是运算步骤少,不仅仅是提高速度,而且可以减少出错的几率,这对于工程来说也是很重要的,必须要尽量减少不确定因素对程序的影响。
下面说下为什么步骤少:
在计算p = p+1的时候,CPU的顺序是这样的
1 。 首先找到p+1中右边p的地址,记住,CPU并不知道左边的p和右边的p是同一个地址,他会将这两个p视为两个不同的变量。
2. 找到右边的p的地址后,然后加1,
3,这一步就是找左边的p的地址。
4,。将结果赋值给左边的p。结束
5. 计算机是不是很笨,是的,他很笨,但是他速度快,并且他严格按照规矩办事,所以一般不会出现错误。
当执行p++的时候。
1.找到p的地址,然后加1,结束。
可以看出,p=p+1和p++结果是一样的,但是这个计算过程是不一样的。这才是他们的区别。
祝你进步!
这2句的结果是一样的,相信楼主也是知道的,都表示p+1然后结果存储在p中。
但是所有的研发还是实验,如果碰到自加1的运算都会选择p++,这里面的关键点是p++的运算速度比p=p+1快,虽然一条语句说快能块多少呢?但是运算步骤少,不仅仅是提高速度,而且可以减少出错的几率,这对于工程来说也是很重要的,必须要尽量减少不确定因素对程序的影响。
下面说下为什么步骤少:
在计算p = p+1的时候,CPU的顺序是这样的
1 。 首先找到p+1中右边p的地址,记住,CPU并不知道左边的p和右边的p是同一个地址,他会将这两个p视为两个不同的变量。
2. 找到右边的p的地址后,然后加1,
3,这一步就是找左边的p的地址。
4,。将结果赋值给左边的p。结束
5. 计算机是不是很笨,是的,他很笨,但是他速度快,并且他严格按照规矩办事,所以一般不会出现错误。
当执行p++的时候。
1.找到p的地址,然后加1,结束。
可以看出,p=p+1和p++结果是一样的,但是这个计算过程是不一样的。这才是他们的区别。
祝你进步!
展开全部
我给你举个例子,假设定义一个double 类型数组,每个是4个字节,所以,p+1表示指针移动了一个位置,也就是P+4,而P++只是p+1
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
p+1和p++都表示是指针移动一个单位,只是p++要使用完本次指针才移动一个单位的,而p+1则是将指针移动一位才使用的。。。。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
p+1只是指针向后移一位,此时p本身指向的值不变,p++则是p指向它后一位指针指向的值。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
p+1执行后p的值是p,而p++执行后p的值是p+1。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询