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

为什么引入并发

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

并发的三大特性

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

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

相关推荐
ONExiaobaijs2 小时前
Java jdk运行库合集
java·开发语言·python
wangjialelele2 小时前
二刷C语言后,一万字整理细碎知识点
c语言·开发语言·数据结构·c++·算法·cpp
mjhcsp2 小时前
P3145 [USACO16OPEN] Splitting the Field G(题解)
开发语言·c++·算法
rit84324992 小时前
UVE算法提取光谱特征波长的MATLAB实现与应用
开发语言·算法·matlab
Coder_Boy_3 小时前
基于SpringAI的在线考试系统-教学管理与用户管理模块联合回归测试文档
java·前端·数据库·人工智能·spring boot
Knight_AL3 小时前
一文讲透 Java 中transient的用处(结合 Flink 理解)
java·python·flink
阿蒙Amon3 小时前
C#每日面试题-简述反射
开发语言·面试·c#
越甲八千3 小时前
python socket
开发语言·python
xqqxqxxq3 小时前
《智能仿真无人机平台(多线程V1.0)技术笔记》(初识线程,带你理解程序运行的基本流程)
java·笔记
缺点内向3 小时前
告别“复制粘贴”:用C#和模板高效生成Word文档
开发语言·c#·word