南京达内IT培训
美国上市IT培训机构

025-66630866

热门课程

Java内存模型常见问题解析

  • 时间:2016-06-16 18:02
  • 发布:南京达内培训学校
  • 来源:企业面试题

南京达内培训讲师表示,Java内存模型规定所有的变量都是存在主存当中(类似于前面说的物理内存),每个线程都有自己的工作内存(类似于前面的高速缓存)。线程对变量的所有操作都必须在工作内存中进行,而不能直接对主存进行操作。并且每个线程不能访问其他线程的工作内存。也就是说,在java内存模型中,也会存在缓存一致性问题和指令重排序的问题。

1.原子性

在Java中,对基本数据类型(除了long和double)的变量的读取和赋值操作是原子性操作,即这些操作是不可被中断的,要么执行,要么不执行。还有一些原子类,如AtomicInteger、AtomicBoolean等等。

2.可见性

对于可见性,Java提供了volatile关键字来保证可见性。

当一个共享变量被volatile修饰时,它会保证修改的值会立即被更新到主存,当有其他线程需要读取时,它会去内存中读取新值。

而普通的共享变量不能保证可见性,因为普通共享变量被修改之后,什么时候被写入主存是不确定的,当其他线程去读取时,此时内存中可能还是原来的旧值,因此无法保证可见性。

另外,通过synchronized和Lock也能够保证可见性,synchronized和Lock能保证同一时刻只有一个线程获取锁然后执行同步代码,并且在释放锁之前会将对变量的修改刷新到主存当中。因此可以保证可见性。

3.有序性

在Java内存模型中,允许编译器和处理器对指令进行重排序,但是重排序过程不会影响到单线程程序的执行,却会影响到多线程并发执行的正确性。

在Java里面,可以通过volatile关键字来保证一定的有序性。另外可以通过synchronized和Lock来保证有序性,很显然,synchronized和Lock保证每个时刻是有一个线程执行同步代码,相当于是让线程顺序执行同步代码,自然就保证了有序性。
上一篇:Java线程的join方法
下一篇:学习java技术的优势有哪些
选择城市和中心
贵州省

广西省

海南省