synchronized具有原子性、可见性、有序性、可重入性
原子性:原子性是指在一个任务执行中cpu不可以在中途暂停然后再调度,即操作不能被中断,要不就执行完成,要不就不执行。例如: int a = 10; 这个操作是不可分割的,那么它就是原子性操作。而int b = a+10; 这个操作是可以分割的那么就不是原子性操作。
可见性:线程修改主内存(堆、方法区,被所有线程共享的内存)中的数据之后其它线程操作该数据时都可以看到被修改后的值。
有序性:是指在同一个线程中的所有操作都是有序执行的,但是由于指令重排序等行为会导致指令执行的顺序不一定是按照代码中的先后顺序执行的
可重入性:synchronized的可重入性就是当一个线程调用synchronized代码持有对象锁的时候,如果调用了该对象的其他synchronized代码,那么可以重新持有该锁,即同一个线程可以获取同一把锁多次,所以synchronized具有可重入性。