一、i++和++i的区别
i++ :先引用后增加 (先在i所在的表达式中使用i的当前值,后让i加1)
++i :先增加后引用 (让i先加1,然后在i所在的表达式中使用i的新值)
i-- :先引用后自减 (先在i所在的表达式中使用i的当前值,后让i减1)
–i :先自减后引用 (让i先减1,然后在i所在的表达式中使用i的新值)
我们举个例子:
public static void main(String[] args) {
//i++ :先引用后增加 (先在i所在的表达式中使用i的当前值,后让i加1)
//++i :先增加后引用 (让i先加1,然后在i所在的表达式中使用i的新值)
//i-- :先引用后自减 (先在i所在的表达式中使用i的当前值,后让i减1)
//--i :先自减后引用 (让i先减1,然后在i所在的表达式中使用i的新值)
int a = 1;
int b = 1;
int c = a++;
int d = ++b;
System.out.println("int c = a++ : c=" + c + "-----a=" + a);
System.out.println("int d = ++b : d=" + d + "-----b=" + b);
int e = 1;
int f = 1;
int g = e--;
int h = --f;
System.out.println("int g = e-- : g=" + g + "-----e=" + e);
System.out.println("int h = --f : h=" + h + "-----f=" + f);
}
下面是运行结果:
二、多线程中的i++线程安全吗?为什么?
答案是不安全的,先来看一下i++的实现过程:
1、先是寄存器从内存中读取i,
2、然后在寄存器中进行+1操作,
3、最后+1后的值回传内存,
因为没有保证原子操作,万一出现3步没有执行完而线程的CPU时间片已经用完,导致操作失败,所以并不安全。
这里有两种方法可以保证线程安全:
1.使用synchronize进行加锁操作,但是影响效率
2.使用CAS乐观锁技术,CAS是一种轻量级锁,是通过CPU硬件指令来实现的,通过总线加锁的方式,指令能保证CPU寄存器和内存交换数据是原子操作,具体使用CAS下的原子操作类AtomicInteger