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

为什么引入并发

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

并发的三大特性

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

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

相关推荐
笃行客从不躺平6 小时前
接口幂等性(Idempotency)
java
Hero | 柒6 小时前
JAVA反射机制
java·spring·反射
j***63086 小时前
Springboot项目中线程池使用整理
java·spring boot·后端
likuolei6 小时前
Eclipse 创建 Java 接口
java·数据库·eclipse
q***54756 小时前
Spring Boot 经典九设计模式全览
java·spring boot·设计模式
a***56066 小时前
Spring Boot接收参数的19种方式
java·spring boot·后端
程序喵大人6 小时前
推荐个C++高性能内存分配器
开发语言·c++·内存分配
liu****6 小时前
27.epoll(三)
服务器·开发语言·网络·tcp/ip·udp
福尔摩斯张6 小时前
Axios源码深度解析:前端请求库设计精髓
c语言·开发语言·前端·数据结构·游戏·排序算法