时间:2021-05-19
废话不多说了,直接给大家贴代码了,具体代码如下所示:
public class Add { public static void main(String[] args) { int i = 0; i=i++ + ++i; int j = 0; j= ++j + j++ + j++ + j++; int k = 0; k=k++ + k++ + k++ + ++k; int h = 0; h=++h + ++h; int p1=0,p2=0; int q1=0,q2=0; q1=+p1; q2=p2++; System.out.println("i "+i); System.out.println("j "+j); System.out.println("k "+k); System.out.println("h "+h); System.out.println("p1 "+p1); System.out.println("p2 "+p2); System.out.println("q1 "+q1); System.out.println("q2 "+q2); }}输出
i 2
j 7
k 7
h 3
p1 0
p2 1
q1 1
q2 0
解析:i++和++i使用的不同点在于一个是程序完毕后的自增,一个是程序开始前的自增。
“i=i++ + ++i”执行的过程是先执行i++,但是i自增1操作是稍后才执行,所以此时i还是0,然后执行++i,++i后i的值是1,执行完++i后要补增i++,所以此时i的值实际上是2,0+2=2,然后赋值给i,最终i的值是2.
“j= ++j + j++ + j++ + j++”,执行的过程是先++j,所以j的值是1,然后执行j++,j++后j的值仍然是1,然后再执行j++,执行后的结果仍然是1,但要补增刚才的j++,所以此时j的实际值是2,然后执行最后一个j++,执行后的结果仍然是2,但要补增刚才的j++,所以此时j的值实际上是3,所以1+1+2+3=7,然后赋值给j,j的最终值是7.
“k=k++ + k++ + k++ + ++k”执行的过程是先k++,所以k的值是0,然后执行k++,k++后k的值仍然是0,但要补增刚才的k++,所以此时k的值实际上是1,然后再执行最后一个k++,执行后的结果仍然是1,但要补增刚才的k++,所以此时K的值实际上的2,最后执行++k,执行结果为3,再补增刚才的k++,k的实际结果是4,所以0+1+2+4=7,然后赋值给k,最终k的值是7。
“h=++h + ++h”是先自增h,h值为1,再自增好,h值为2,所以1+2=3,然后赋值给h,最终h的值是3.
“q1=++p1”先自增p1,p1的值是1,再赋值给 q1,所以q1的值是1.
“q2=p2++”先赋值p2给q2,q2的值是0,然后再自增p2,所以p2的值是1。
以上所述是小编给大家介绍的java自加和自减运算过程,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
01++、--运算符重载函数的格式自增运算符和自减运算符是有前置和后置之分的,如:a++//后置自增运算符++a//前置自增运算符b--//后置自减运算符--b
自增自减++自增运算符:如a++,++a都等价于a=a+1;–自减运算符:如a–,–a都等价于a=a-1;++a和a++的区别虽然++a和a++等价的结果一样,
一:算术运算符1.算术运算符有哪些①基本四则运算符:+-*/%②增量赋值运算符:+=-=*=/=%=③自增/自减运算符++–2.如何使用算术运算符publicc
c语言a++和++a两者都是自增运算符,a++是使用的a后,再对a进行加1。++a是先把a加1,然后再使用a。 C语言是一门面向过程的、抽象化的通用程序设计语
(一)a++在C语言或其它语言中,++符号表示“自加”,就是变量在原来的基础上加1。例1:a=0;a++;则此时a的值为1。同样的道理,--表示”自减”。例2: