【Java并发编程一】并发与并行

为什么引入并发

摩尔定理逐渐失效,单核性能很难提升,通过组合多核性能来进一步满足实际需要,从而引入并发编程。在大部分场景下,并行是由于串行的,并行可以优化非关键节点的时间消耗。

并发的三大特性

  1. 原子性
     某个操作不可被中断,不可被分割。
  2. 可见性
     对于一些变量的修改,需要告知其他线程。
  3. 有序性
     由于编译器的设计者为了提高程序的效率,由此引入了指令重排。对于值的读取与修改需要多个步骤,对指令进行重排可以提高效率。这对串行没有影响,但会让并行程序出错。解决措施之一是引入volatile关键字:
java 复制代码
volatile int num;

这样程序就不会对含有volatile关键字的指令进行重排。

相关推荐
cnxy18812 分钟前
围棋对弈Python程序开发完整指南:步骤1 - 棋盘基础框架搭建
开发语言·python
Nonoas1 小时前
动态代理:发布订阅的高级玩法
java·ide·intellij-idea
程序员-周李斌1 小时前
Java 死锁
java·开发语言·后端
皮皮林5512 小时前
Prometheus+Grafana,打造强大的监控与可视化平台
java
JasmineWr2 小时前
CompletableFuture相关问题
java·开发语言
零雲2 小时前
java面试:知道java的反射机制吗
java·开发语言·面试
Jeremy爱编码2 小时前
实现 Trie (前缀树)
开发语言·c#
laocooon5238578863 小时前
插入法排序 python
开发语言·python·算法
你的冰西瓜3 小时前
C++中的list容器详解
开发语言·c++·stl·list
java1234_小锋3 小时前
Java进程占用的内存有哪些部分?
java