关于c语言中的a++ ,++b的运算
a++是先运算完在把a的值加1++b是先把b的值加1在运算对吗如果不对那是怎么样的啊假设a为1b为2a+b=?...
a++是先运算完在把a的值加1 ++b是先把b的值加1 在运算 对吗 如果不对 那是怎么样的啊 假设a为1 b为2 a+b=?
展开
3个回答
2013-10-31
展开全部
楼上举出了一个错误的例子。(a++)+(a++)这个例子是错误的。C语言规定,在相邻的运算中不能连续多次改变同一个变量的值,上面的式子显然不符合这一点。当然,我并不是说上面的式子编译不通过,而是说上面的式子是ANSI标准中定义为不合法的形式。这个式子在C语言标准中没有给出标准的运算法则,但是在语法上又没有错误,因此不同的编译器会进行不同的解释,其结果也就不一样。我给出两种编译器的解释,假设a的初始值为1。1、(a++)+(a++)=3 理由 编译器会认为第一次(a++)为1,第二次(a++)为2,因此结果为3。2、(a++)+(a++)=4 理由 有些编译器会认为这是两个相同变量相加,于是就会取第二个a++的值作为变量值,也就是先执行两次a++将第二次的值(2)作为编译器所认为的相同变量的值,也就是2+2,因此结果为4。因此,像这种同一个变量连续自增的表达式是不符合规范的,也是标准程序开发中不可用的(在这里鄙视一下谭浩强的书)。 下面我来简单解释一下自增运算。首先在C语言里有一个概念,那就是“表达式的值”。在大多数情况下,按照运算优先级进行的运算结果就是表达式的值。有个很明显的特例,那便是后置自增运算。将a++看作一个表达式,那么a++的表达式的值就是1(假定a的初始值为1),而a=2再比如1<2这个表达,表达式的值为非0(一般说法是1,但是C语言对“真”的表述为非0)。因此,要理解C语言中表达式的值和变量的计算结果就会理解自增运算了。从编译原理角度来说这是由于堆栈的特点导致的,如果你将来会对C语言进行深入的学习会理解的
TableDI
2024-07-18 广告
2024-07-18 广告
VLOOKUP函数是Excel中用于数据匹配的重要工具。其使用方法是:在个参数中输入要查找的值,第二个参数是包含数据的范围或表格,第三个参数指定返回数据的列号,第四个参数(可选)决定查找方式(0为精确匹配,其他为近似匹配)。例如,假设我们想...
点击进入详情页
本回答由TableDI提供
2013-10-31
展开全部
对于前置++ 和 后置++ 最基本的理解就是你那样的。所以(a++) + (++b) = 1 + 3 = 4a++这个表达式的结果就是a;而++b表达式的结果是b+1.
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
2013-10-31
展开全部
你说的是对的
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询