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

为什么引入并发

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

并发的三大特性

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

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

相关推荐
phltxy几秒前
Redis 主从复制
java·数据库·redis
Full Stack Developme1 分钟前
Spring-Core 解析
java·spring·rpc
2301_809244538 分钟前
C#怎么使用协变和逆变 C#泛型中的in和out关键字协变逆变是什么意思怎么用【语法】
jvm·数据库·python
知识汲取者17 分钟前
巨量引擎营销 API 完整文档
开发语言·数据库·python
BING_Algorithm26 分钟前
深入理解JVM垃圾回收
jvm·后端·面试
摇滚侠26 分钟前
针对主键索引的 for update 操作有什么用
java
Larry_Yanan34 分钟前
QML面试常见问题(一)QML中组件呈现方式的方法有哪些
开发语言·c++·qt·ui·面试
Aurorar0rua34 分钟前
CS50 x 2024 Notes C -12
c语言·开发语言·学习方法
RainCity1 小时前
Java Swing 自定义组件库分享(六)
java·笔记·后端
techdashen1 小时前
深入 Rust enum 的内存世界
开发语言·后端·rust