auto commit

This commit is contained in:
CyC2018 2019-08-11 23:10:46 +08:00
parent 353bbf6af0
commit fbf0eba5fd
4 changed files with 10 additions and 10 deletions

View File

@ -63,8 +63,8 @@ boolean 只有两个值true、false可以使用 1 bit 来存储,但是
基本类型都有对应的包装类型基本类型与其对应的包装类型之间的赋值使用自动装箱与拆箱完成 基本类型都有对应的包装类型基本类型与其对应的包装类型之间的赋值使用自动装箱与拆箱完成
```java ```java
Integer x = 2; // 装箱 Integer x = 2; // 装箱 调用了 Integer.valueOf(2)
int y = x; // 拆箱 int y = x; // 拆箱 调用了 Integer.intValue(x)
``` ```
## 缓存池 ## 缓存池
@ -154,7 +154,7 @@ System.out.println(m == n); // true
## 概览 ## 概览
String 被声明为 final因此它不可被继承 String 被声明为 final因此它不可被继承(Integer 等包装类也不能被继承
Java 8 String 内部使用 char 数组存储数据 Java 8 String 内部使用 char 数组存储数据

View File

@ -1329,10 +1329,10 @@ synchronized 和 ReentrantLock。
互斥同步属于一种悲观的并发策略总是认为只要不去做正确的同步措施那就肯定会出现问题无论共享数据是否真的会出现竞争它都要进行加锁这里讨论的是概念模型实际上虚拟机会优化掉很大一部分不必要的加锁用户态核心态转换维护锁计数器和检查是否有被阻塞的线程需要唤醒等操作 互斥同步属于一种悲观的并发策略总是认为只要不去做正确的同步措施那就肯定会出现问题无论共享数据是否真的会出现竞争它都要进行加锁这里讨论的是概念模型实际上虚拟机会优化掉很大一部分不必要的加锁用户态核心态转换维护锁计数器和检查是否有被阻塞的线程需要唤醒等操作
### 1. CAS
随着硬件指令集的发展我们可以使用基于冲突检测的乐观并发策略先进行操作如果没有其它线程争用共享数据那操作就成功了否则采取补偿措施不断地重试直到成功为止这种乐观的并发策略的许多实现都不需要将线程阻塞因此这种同步操作称为非阻塞同步 随着硬件指令集的发展我们可以使用基于冲突检测的乐观并发策略先进行操作如果没有其它线程争用共享数据那操作就成功了否则采取补偿措施不断地重试直到成功为止这种乐观的并发策略的许多实现都不需要将线程阻塞因此这种同步操作称为非阻塞同步
### 1. CAS
乐观锁需要操作和冲突检测这两个步骤具备原子性这里就不能再使用互斥同步来保证了只能靠硬件来完成硬件支持的原子性操作最典型的是比较并交换Compare-and-SwapCASCAS 指令需要有 3 个操作数分别是内存地址 V旧的预期值 A 和新值 B当执行操作时只有当 V 的值等于 A才将 V 的值更新为 B 乐观锁需要操作和冲突检测这两个步骤具备原子性这里就不能再使用互斥同步来保证了只能靠硬件来完成硬件支持的原子性操作最典型的是比较并交换Compare-and-SwapCASCAS 指令需要有 3 个操作数分别是内存地址 V旧的预期值 A 和新值 B当执行操作时只有当 V 的值等于 A才将 V 的值更新为 B
### 2. AtomicInteger ### 2. AtomicInteger

View File

@ -63,8 +63,8 @@ boolean 只有两个值true、false可以使用 1 bit 来存储,但是
基本类型都有对应的包装类型基本类型与其对应的包装类型之间的赋值使用自动装箱与拆箱完成 基本类型都有对应的包装类型基本类型与其对应的包装类型之间的赋值使用自动装箱与拆箱完成
```java ```java
Integer x = 2; // 装箱 Integer x = 2; // 装箱 调用了 Integer.valueOf(2)
int y = x; // 拆箱 int y = x; // 拆箱 调用了 Integer.intValue(x)
``` ```
## 缓存池 ## 缓存池
@ -154,7 +154,7 @@ System.out.println(m == n); // true
## 概览 ## 概览
String 被声明为 final因此它不可被继承 String 被声明为 final因此它不可被继承(Integer 等包装类也不能被继承
Java 8 String 内部使用 char 数组存储数据 Java 8 String 内部使用 char 数组存储数据

View File

@ -1329,10 +1329,10 @@ synchronized 和 ReentrantLock。
互斥同步属于一种悲观的并发策略总是认为只要不去做正确的同步措施那就肯定会出现问题无论共享数据是否真的会出现竞争它都要进行加锁这里讨论的是概念模型实际上虚拟机会优化掉很大一部分不必要的加锁用户态核心态转换维护锁计数器和检查是否有被阻塞的线程需要唤醒等操作 互斥同步属于一种悲观的并发策略总是认为只要不去做正确的同步措施那就肯定会出现问题无论共享数据是否真的会出现竞争它都要进行加锁这里讨论的是概念模型实际上虚拟机会优化掉很大一部分不必要的加锁用户态核心态转换维护锁计数器和检查是否有被阻塞的线程需要唤醒等操作
### 1. CAS
随着硬件指令集的发展我们可以使用基于冲突检测的乐观并发策略先进行操作如果没有其它线程争用共享数据那操作就成功了否则采取补偿措施不断地重试直到成功为止这种乐观的并发策略的许多实现都不需要将线程阻塞因此这种同步操作称为非阻塞同步 随着硬件指令集的发展我们可以使用基于冲突检测的乐观并发策略先进行操作如果没有其它线程争用共享数据那操作就成功了否则采取补偿措施不断地重试直到成功为止这种乐观的并发策略的许多实现都不需要将线程阻塞因此这种同步操作称为非阻塞同步
### 1. CAS
乐观锁需要操作和冲突检测这两个步骤具备原子性这里就不能再使用互斥同步来保证了只能靠硬件来完成硬件支持的原子性操作最典型的是比较并交换Compare-and-SwapCASCAS 指令需要有 3 个操作数分别是内存地址 V旧的预期值 A 和新值 B当执行操作时只有当 V 的值等于 A才将 V 的值更新为 B 乐观锁需要操作和冲突检测这两个步骤具备原子性这里就不能再使用互斥同步来保证了只能靠硬件来完成硬件支持的原子性操作最典型的是比较并交换Compare-and-SwapCASCAS 指令需要有 3 个操作数分别是内存地址 V旧的预期值 A 和新值 B当执行操作时只有当 V 的值等于 A才将 V 的值更新为 B
### 2. AtomicInteger ### 2. AtomicInteger