并发编程理论基础——可见性、原子性和有序性问题(一)

核心问题:分工,同步,互斥
- 分工:如何高效地拆解任务并分配给线程
- 生产者-消费者模式、Thread-Per-Message模式、Worker-Thread模式、ComplateableFuture和CompletionService
- Java SDK 并发包里的 Executor、Fork/Join、Future 本质上都是一种分工方法
- 同步:线程之间如何协作
- 一个线程执行完了一个任务,如何通知执行后续任务的线程开工
- Java SDK 里提供的 CountDownLatch、CyclicBarrier、Phaser、Exchanger
- 互斥:保证同一时刻只允许一个线程访问共享资源
- 导致不确定的主要源头是可见性问题、有序性问题和原子性问题
- Java SDK 里提供的 ReadWriteLock、StampedLock 可以优化读多写少场景下锁的性能
可见性、原子性和有序性问题
- 可见性:一个线程对共享变量的修改,另外一个线程能够立刻看到
- 原子性:我们把一个或者多个操作在 CPU 执行的过程中不被中断的特性称为原子性
- 有序性:Java内存模型中,允许编译器和处理器对指令进行重排序,但是重排序过程不会影响到单线程程序的执行,却会影响到多线程并发执行的正确性。
- 缓存导致的可见性问题:当多个线程在不同的 CPU 上修改同一个变量时,因为多个线程不是同时启动的,有一个时差可能会导致值不一样。
- 线程切换带来的原子性问题:
- 首先将变量从内存中加载到CPU寄存器
- 之后执行操作
- 最终将结果写入内存(缓存机制导致可能写入的是CPU缓存而不是内存)
- (单例模式的双重检测,new指令也是3步操作,①分内存②初始化③赋值给引用变量,可能会发生①③②的重排序,这时候如果又有操作系统的分时操作的加持,导致A操作①③后挂起,时间片被分配给了B线程,而B线程甚至都不需要进行锁的获取,因为此时instance已经不等于null了,但是此时的instance可能未初始化)
相关文章:
并发编程理论基础——可见性、原子性和有序性问题(一)
核心问题:分工,同步,互斥 分工:如何高效地拆解任务并分配给线程 生产者-消费者模式、Thread-Per-Message模式、Worker-Thread模式、ComplateableFuture和CompletionServiceJava SDK 并发包里的 Executor、Fork/Join、Future 本质上…...
心理咨询系统源码|心理咨询系统开发|心理咨询系统
心理咨询系统,作为一种集现代化科技与专业心理服务于一体的工具,正逐渐渗透到我们生活的各个角落。它不仅为个人提供了便捷的心理支持,还为企业和组织带来了全新的管理方式。下面,我们将深入探讨心理咨询系统的可应用范围及其带来…...
Vue21-列表排序
一、需求 二、解决方式 <body><div id"root"><h2>人员列表</h2><input type"text" placeholder"请输入" v-model"keyword"><button click"sortType 1">年龄升序</button><b…...
配置 JDK 和 Android SDK
目录 一、配置JDK 1. 安装 JDK 2. JDK 环境配置 3. JDK的配置验证 二、配置 adb 和Android SDK环境 1、下载 2、配置 Android SDK 环境 一、配置JDK 1. 安装 JDK 安装链接:Java Downloads | Oracle 我安装的是 .zip ,直接在指定的文件夹下解压就…...
pyechart 创建柱形图
Pyecharts 是一个基于 Python 的开源数据可视化库,用于创建各种交互式的图表和可视化效果。它是在 Echarts 的基础上进行封装和优化,Echarts 是一个流行的 JavaScript 数据可视化库pyecharts 中文网站 : https://pyecharts.org/# pyecharts 模块 还支持…...
c#引用dll报错cs8370功能“本地函数特性“在c#7.3中不可用
cs8370:功能"本地函数特性"在c#7.3中不可用 解决方法: 代码放在form类里面...
【STM32】输入捕获应用-测量脉宽或者频率(方法1)
图1 脉宽/频率测量示意图 1 测量频率 当捕获通道TIx 上出现上升沿时,发生第一次捕获,计数器CNT 的值会被锁存到捕获寄存器CCR中,而且还会进入捕获中断,在中断服务程序中记录一次捕获(可以用一个标志变量来记录&#…...
C# Task
以下是 Task 类的一些关键特性和用法:以下是一些使用 Task 的示例:创建并启动一个任务使用 await 等待任务完成处理任务异常使用 Task<TResult> 获取结果取消任务 总结 在 C#中, Task 是 System.Threading.Tasks 命名空间中的一个类…...
进口电动蝶阀的工作原理-美国品牌
进口电动蝶阀通过电力驱动,实现阀门的开启、关闭和流量调节功能。其结构简单、操作方便、精确控制的特点使其在多个领域得到广泛应用。 进口电动蝶阀的工作原理可以清晰地分点表示和归纳如下: 一、概述 进口电动蝶阀是由电动执行器和蝶形阀组成的一种…...
Exploring Performance and Cost Optimization with ASIC-Based CXL Memory——论文阅读
EuroSys 2024 Paper CXL论文阅读笔记整理 问题 随着内存密集型应用程序对内存需求的增加,受限于物理限制,如DDR DIMM插槽的可用性和发热问题,以及使用高密度DIMM的成本考虑,现代应用程序的内存需求很容易超过单机的内存容量[2&a…...
计算机网络(4) 最长前缀匹配(路由转发表)
一.路由转发 网络数据包IP段只包含源地址与目的地址,经过数据链路层包装与物理层信号形式转换,最终经由不同的链路节点到达目的地址。这个过程是一步一步(hop by hop)进行的,路过一个路由节点则称为一跳。每个路由节点…...
向https地址发送请求失败报错
错误1: 10:13:47.520 [main] DEBUG org.apache.http.conn.ssl.SSLConnectionSocketFactory - Starting handshake 10:13:47.523 [main] DEBUG org.apache.http.impl.conn.DefaultManagedHttpClientConnection - http-outgoing-0: Shutdown connection 10:13:47.523…...
生信技能47 - Shell程序和R程序并行执行处理方法
Linux shell和R程序并行化执行程序方法。 1. 使用do{…} &;done;wait语句并行执行Shell 并行执行总运行时间不再是task数量*单个任务消耗时间,而是取决于单个耗时最长的任务。 # while循环,遍历test.txt文件每行 cat test.txt|while read i; dotime_stamp=$(date &quo…...
java+SimpleRegression 线性模型,针对采集到的大数据设备温度,对设备温度做出预测
首先,让我们通过以下表格展示预测模型开发 Java 的整体流程: 步骤 描述 1 数据收集与清洗 2 特征工程处理 3 模型选择与训练 4 模型评估与调优 5 模型应用与部署 然后引入java的类库 org.apache.commons.math3 math使用原则 math3可谓是轻量级自容器…...
面对失业,不得不做出改变了
有没有发现最近挣钱很难,生活压力很大 大批企业纷纷裁员,大量的就业岗位被机器人机械臂取代 很多的传统职业也将被AI替代, 比如工厂螺丝钉、司机、客服、甚至程序员、医生、等等 众多大厂开发无人驾驶出租车,让本来处在底层的网约车司机无…...
MT2093 活动安排
贪心策略: 每次选择结束时间最早的活动 代码: #include <bits/stdc.h> using namespace std; const int N 5e5 10; int n; struct pp {int a, b; } p[N]; bool cmp(pp x, pp y) {return x.b < y.b; } int ans 0;int main() {cin >>…...
动态javaweb 建立-准备阶段
一、实验内容: 1.定义一个inputjsp页面接收数据输入的长和宽。 2.创建一个javaBean,包含长、宽和面积三个成员变量,分别有对应的get方法和set方法。 3.定义一个业务模型calculate.java,用来计算矩形的面积。 4.定义一个…...
web前端网页设计参考:深度剖析与设计思路探索
web前端网页设计参考:深度剖析与设计思路探索 在Web前端开发领域,网页设计占据着举足轻重的地位。一个优秀的网页设计不仅能提升用户体验,还能有效传达品牌价值和信息。本文将从四个方面、五个方面、六个方面和七个方面,深入剖析…...
node使用http-proxy-middleware做代理,解决跨域问题
const express require(express) const history require(connect-history-api-fallback) const { createProxyMiddleware } require(http-proxy-middleware)let app express()app.use(history())// //匹配api开头的请求,实际转发的请求保api这三个字母 // app.u…...
爱奇艺视频怎么转换成mp4格式,爱奇艺qsv转换mp4最简单方法
在数字化时代,视频格式的转换成为了我们日常生活中常见的需求。特别是对于那些经常从各大视频平台下载视频的朋友来说,将特定格式的视频转换为更通用的格式,如MP4,变得尤为重要。其中,qsv格式的视频转换就是一项常见的…...
易语言DLL注入工具(含完整源码+窗口Hook实战示例)
温馨提示:文末有联系方式产品核心功能概述 本工具是一款采用易语言开发的Windows平台DLL注入解决方案,支持将指定动态链接库注入至目标进程,并对目标窗口实施消息钩取(Hook),实现UI层行为拦截与增强。 内置…...
攻克向量扩展加载难题:MacOS环境下SQLite-Vec实战指南
攻克向量扩展加载难题:MacOS环境下SQLite-Vec实战指南 【免费下载链接】sqlite-vec Work-in-progress vector search SQLite extension that runs anywhere. 项目地址: https://gitcode.com/GitHub_Trending/sq/sqlite-vec 在数据驱动开发的浪潮中࿰…...
SpringBoot+Vue3构建企业级数据可视化驾驶舱
1. 企业级数据可视化驾驶舱的核心价值 数据可视化驾驶舱已经成为现代企业决策的神经中枢。想象一下飞机驾驶舱里密密麻麻的仪表盘——每个指标都在实时告诉你飞机的状态。企业驾驶舱也是同样的逻辑,只不过我们把飞行数据换成了销售额、用户增长、库存周转率这些业务…...
Qwen3-Reranker-8B跨平台部署:Windows与Linux对比
Qwen3-Reranker-8B跨平台部署:Windows与Linux对比 1. 引言 如果你正在寻找一个强大的文本重排序模型,Qwen3-Reranker-8B绝对值得关注。这个80亿参数的大模型在多项评测中表现优异,支持100多种语言,能够智能判断文档与查询的相关…...
AI写论文优选!4款AI论文生成工具揭秘,高效搞定期刊论文不发愁!
AI论文写作工具实测推荐 还在为撰写期刊论文而烦恼吗?面对海量的学术文献、繁杂的格式要求和反复修改的过程,很多学术工作者都感到力不从心!但是不要担心,以下推荐的4款AI论文写作工具,经过实测,能够帮助你…...
摒弃固定采样频率,程序让仪器根据信号变化快慢,自动调整采样频率,兼顾精度和省电。
一、实际应用场景描述在《智能仪器与信号处理》课程实验中,学生常遇到两类设备:- 高速采集卡:固定 10kHz 采样- 低功耗传感器节点:固定 1Hz 采样但实际信号往往是这样的:- 静止状态 → 信号几乎不变- 突变瞬间 → 需要…...
SpringBoot3 + SpringDoc + Knife4j:打造一个带中文界面和API分组的超实用接口文档(保姆级YAML配置)
SpringBoot3 SpringDoc Knife4j:企业级API文档中心实战指南 在微服务架构盛行的今天,一套清晰、易用的API文档系统已成为团队协作的刚需。本文将带您从零构建一个支持中文界面、智能分组、在线调试的企业级文档中心,基于SpringBoot3最新技术…...
供应链人必看:用Excel快速实现(s,S)库存策略的3种方法
供应链人必看:用Excel快速实现(s,S)库存策略的3种方法 在制造业和零售业的日常运营中,库存管理始终是供应链从业者的核心挑战之一。面对波动的市场需求和有限的仓储空间,如何在保证服务水平的同时最小化库存成本?(s,S)库存策略作为…...
Spring开发系列教程(11)——AOP之使用注解装配AOP
上一节我们讲解了使用AspectJ的注解,并配合一个复杂的execution(* xxx.Xyz.*(..))语法来定义应该如何装配AOP。在实际项目中,这种写法其实很少使用。假设你写了一个SecurityAspect:Aspect Component public class SecurityAspect {Before(&qu…...
5步让老旧Mac重获新生:开源工具优化性能指南
5步让老旧Mac重获新生:开源工具优化性能指南 【免费下载链接】OpenCore-Legacy-Patcher 体验与之前一样的macOS 项目地址: https://gitcode.com/GitHub_Trending/op/OpenCore-Legacy-Patcher 老旧Mac升级新版macOS后是否遇到界面卡顿、视频播放掉帧等问题&am…...
