CAS in Java

CAS in Java

需求描述

需求分析

部署图

组件图

时序图

并发:在一个时间段内发生若干事件;

并行:在同一时刻发生若干事件;

例如使用单核 CPU,多个工作任务是以并发方式运行的,因为只有一个 CPU,各个任务分别占用一段时间,再切换到其他任务,等到下一次 CPU 使用权是再次执行未完成的任务。

使用多核 CPU 时,可以将任务分配到不同的核同时运行,实现并行。

CPU 的基本组成

超线程

超线程技术把多线程处理器内部的两个逻辑内核模拟成两个物理芯片,让单个处理器就能使用线程级的并行计算。

缓存对齐

CPU 的乱序执行(指令重排)

为了提升计算性能,CPU 从单核升级到了多核甚至用到了超线程技术最大化提高 CPU 的处理性能。CPU增加了高速缓存,操作系统增加了进程、线程,通过CPU时间片的切换最大化的提升CPU的使用率。

Java 程序验证

顺序执行 SingleThreadPool

NUMA

linux 内核设计与实现

编码 : 隐匿在计算机软硬件背后的语言

纸带上通过打孔来表示 1、0,出现过一次问题,一个虫子(bug)飞到纸带上,一直沿用程序上的异常被称为 bug。

汇编语言和机器语言是一一对应的,一个汇编命令即一个机器指令。

volatile: 可见性、指令重排

超线程: 4 核 8 线程

一组运算单元 多寄存器

进程、线程、纤程(协程、绿色线程):
运行一个程序就会开启一个进程,在进程中通过线程并行进行工作,协程线程中的并发执行。
区别:进程分配资源的单位、线程不会分配空间是调度单位。

程序的本质是一堆指令

项目驱动、并行学习

kernel/用户层