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

为什么引入并发

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

并发的三大特性

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

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

相关推荐
程序员清风4 小时前
用了三年AI,我总结出高效使用AI的3个习惯!
java·后端·面试
beata4 小时前
Java基础-13: Java反射机制详解:原理、使用与实战示例
java·后端
用户0332126663674 小时前
Java 使用 Spire.Presentation 在 PowerPoint 中添加或删除表格行与列
java
Seven977 小时前
Condition底层机制剖析:多线程等待与通知机制
java
怒放吧德德16 小时前
Spring Boot 实战:RSA+AES 接口全链路加解密(防篡改 / 防重放)
java·spring boot·后端
郑州光合科技余经理19 小时前
代码展示:PHP搭建海外版外卖系统源码解析
java·开发语言·前端·后端·系统架构·uni-app·php
weisian15120 小时前
JVM--20-面试题6:如何判断对象可以被垃圾回收?
jvm·可达性算法
feifeigo12320 小时前
matlab画图工具
开发语言·matlab
大大水瓶20 小时前
Tomcat
java·tomcat
dustcell.20 小时前
haproxy七层代理
java·开发语言·前端