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

为什么引入并发

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

并发的三大特性

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

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

相关推荐
霍田煜熙几秒前
【无标题】
java
无忧智库3 分钟前
深度拆解:某大型医院“十五五”智慧医院建设方案,如何冲刺互联互通五级乙等?(附技术架构与实施路径)
java·数据库·架构
木木木一6 分钟前
Rust学习记录--C8 常用的集合
开发语言·学习·rust
C_心欲无痕6 分钟前
js - AbortController请求中止
开发语言·javascript·ecmascript
yugi9878389 分钟前
基于Matlab的晴空指数计算实现
开发语言·算法·matlab
song1502653729813 分钟前
空间站太阳能帆板电池 组件性能测试 AM0太阳光模拟器
开发语言·python
守护砂之国泰裤辣13 分钟前
Windows+docker下简单kafka测试联调
java·运维·spring boot·docker·容器
不会c嘎嘎14 分钟前
QT中的常用控件 (三)
开发语言·qt
代码方舟14 分钟前
Java企业级风控实战:对接天远多头借贷行业风险版API构建信贷评分引擎
java·开发语言