当前位置: 首页 > article >正文

Book:实战Java高并发程序设计(第二版)

实战Java高并发程序设计(第二版)

  • 为什么会有并行计算?
  • 并行计算需要回答的问题
  • 基本概念
  • 并发级别有哪些?
  • Amdahl定律和Gustafson定律
  • Java并发三特性
  • 进程和线程
  • 线程的生命周期
  • Thread类run()与start()的区别

为什么会有并行计算?

单核CPU → 摩尔定律失效 → 多核CPU → 并行计算

Donald Ervin Kunth对于多核CPU的评价:这种现象或多或少是由于硬件设计师已经无计可施了,他们将摩尔定律失效的责任推给了软件开发者

并行计算需要回答的问题

①如何保证线程安全?
②如何正确理解线程间的无序性和可见性?
③如何将串行程序改造为并行程序?

基本概念

同步和异步(synchronous&asynchronous)

并发和并行(concurrency&parallelism)

临界区(critical section)

阻塞和非阻塞(blocking&non-blocking)

死锁、饥饿和活锁(deadLock、starvation&liveLock)

并发级别有哪些?

①阻塞(blocking):synchronized和可重入锁
②无饥饿(starvation-free):公平锁
③无障碍(obstruction-free):乐观锁
④无锁(lock-free):CAS
⑤无等待(wait-free):RCU

Amdahl定律和Gustafson定律

Java并发三特性

①原子性
②有序性
③可见性 → 指令重排序 → happen-before原则

进程和线程

进程:房子
线程:房子里的人

线程的生命周期

①new
②runnable
③blocked
④waiting
⑤time-waited
⑥terminated

Thread类run()与start()的区别


http://www.kler.cn/a/5317.html

相关文章:

  • 如何建立python应用的docker镜像
  • vue中的$refs(父访子)——访问子组件数据+方法
  • python -- 科研论文海洋气象科学绘图的配色汇总
  • centos挂载磁盘
  • Redis HyperLogLog底层实现和Redis 7.0特性主从复制优化
  • TC275-点亮属于AutoSAR的灯之MCAL配置
  • 【机器学习】线性回归
  • 【C语言督学训练营 第五天】数组字符串相关知识
  • Ceres 自动求导解析-从原理到实践
  • mysql主从(单主)同步原理
  • 信号集操作函数
  • Matbox V1.0.7更新预览与手册
  • TryHackMe-harder(boot2root)
  • ShaderGraph前言
  • English Learning - L2 语音作业打卡 舌边音 [r] [l] Day37 2023.3.29 周三
  • 你知道Python 最常用的 20 个包吗(按照使用频率排序)
  • Java 抽象类中构造方法的作用?如何理解?
  • JS和Jquery
  • 大屏使用dv-digital-flop定时刷新显示总人数
  • 一文实战 | RISC-V Linux入口地址2M预留内存优化