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

为什么引入并发

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

并发的三大特性

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

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

相关推荐
mit6.82416 小时前
[Agent可视化] 配置系统 | 实现AI模型切换 | 热重载机制 | fsnotify库(go)
开发语言·人工智能·golang
友友马16 小时前
『 QT 』QT控件属性全解析 (一)
开发语言·前端·qt
小白学大数据17 小时前
实战:Python爬虫如何模拟登录与维持会话状态
开发语言·爬虫·python
一念&17 小时前
每日一个C语言知识:C 结构体
c语言·开发语言
Chen-Edward17 小时前
有了Spring为什么还有要Spring Boot?
java·spring boot·spring
锦***林17 小时前
用 Python 写一个自动化办公小助手
开发语言·python·自动化
陈小桔18 小时前
idea中重新加载所有maven项目失败,但maven compile成功
java·maven
小学鸡!18 小时前
Spring Boot实现日志链路追踪
java·spring boot·后端
xiaogg367818 小时前
阿里云k8s1.33部署yaml和dockerfile配置文件
java·linux·kubernetes
逆光的July18 小时前
Hikari连接池
java