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

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.lryc.cn/news/44786.html

相关文章:

  • LeetCode 831. Masking Personal Information【字符串,正则表达式】中等
  • 递增三元组
  • java源码阅读 - TreeSet
  • 写毕业论文经验贴
  • 2.7 进程退出、孤儿进程、僵尸进程+2.8 wait函数+2.9 waitpid函数
  • 【新2023Q2模拟题JAVA】华为OD机试 - 预订酒店
  • 一个完整的渗透学习路线是怎样的?如何成为安全渗透工程师?
  • 刷完这60个标准库模块,成为Python骨灰级玩家
  • EasyExcel的简单使用(easyExcel和poi)
  • 命名空间 namespace
  • 我能“C”——初阶指针(上)
  • Android高级工程师工资为何让人艳羡不已
  • 什么猫猫最受欢迎?Python采集猫咪交易数据
  • 使用Nextcloud搭建私人云盘,并内网穿透实现公网远程访问
  • 行业盛会|2023中国(东莞)国际测量控制及仪器仪表展览会
  • redis集群 服务器重启测试
  • Diffusion的unet中用到的AttentionBlock详解
  • ElasticSearch索引文档写入和近实时搜索
  • 【C语言蓝桥杯每日一题】——等差数列
  • EM7电磁铁的技术参数
  • 选择很重要,骑友,怎么挑选骑行装备?
  • 【JUC面试题】Java并发编程面试题
  • spark笔记
  • 丢失了packet.dll原因和解决方法全面指南
  • 算法练习随记(三)
  • 基于Python 进行卫星图像多种指数分析
  • (Week 15)综合复习(C++,字符串,数学)
  • 迪赛智慧数——柱状图(正负条形图):“光棍”排行榜TOP10省份
  • IDEA集成chatGTP让你编码如虎添翼
  • Python3 os.close() 方法、Python3 File readline() 方法