为什么引入并发
摩尔定理逐渐失效,单核性能很难提升,通过组合多核性能来进一步满足实际需要,从而引入并发编程。在大部分场景下,并行是由于串行的,并行可以优化非关键节点的时间消耗。
并发的三大特性
- 原子性
某个操作不可被中断,不可被分割。 - 可见性
对于一些变量的修改,需要告知其他线程。 - 有序性
由于编译器的设计者为了提高程序的效率,由此引入了指令重排。对于值的读取与修改需要多个步骤,对指令进行重排可以提高效率。这对串行没有影响,但会让并行程序出错。解决措施之一是引入volatile关键字:
java
volatile int num;
这样程序就不会对含有volatile关键字的指令进行重排。