Skip to content

Commit 557d658

Browse files
authoredAug 15, 2024··
Merge pull request #2455 from WindLYLY/main
优化表达便于理解
2 parents 9cb8afd + e29f141 commit 557d658

File tree

2 files changed

+6
-2
lines changed

2 files changed

+6
-2
lines changed
 

Diff for: ‎docs/java/concurrent/java-concurrent-questions-03.md

+1-1
Original file line numberDiff line numberDiff line change
@@ -308,7 +308,7 @@ public ScheduledThreadPoolExecutor(int corePoolSize) {
308308

309309
`ThreadPoolExecutor`其他常见参数 :
310310

311-
- `keepAliveTime`:线程池中的线程数量大于 `corePoolSize` 的时候,如果这时没有新的任务提交,核心线程外的线程不会立即销毁,而是会等待,直到等待的时间超过了 `keepAliveTime`才会被回收销毁。
311+
- `keepAliveTime`:当线程池中的线程数量大于 `corePoolSize` ,即有非核心线程(线程池中核心线程以外的线程)时,这些非核心线程空闲后不会立即销毁,而是会等待,直到等待的时间超过了 `keepAliveTime`才会被回收销毁。
312312
- `unit` : `keepAliveTime` 参数的时间单位。
313313
- `threadFactory` :executor 创建新线程的时候会用到。
314314
- `handler` :拒绝策略(后面会单独详细介绍一下)。

Diff for: ‎docs/java/concurrent/jmm.md

+5-1
Original file line numberDiff line numberDiff line change
@@ -61,7 +61,11 @@ Java 源代码会经历 **编译器优化重排 —> 指令并行重排 —> 内
6161

6262
**指令重排序可以保证串行语义一致,但是没有义务保证多线程间的语义也一致** ,所以在多线程下,指令重排序可能会导致一些问题。
6363

64-
编译器和处理器的指令重排序的处理方式不一样。对于编译器,通过禁止特定类型的编译器重排序的方式来禁止重排序。对于处理器,通过插入内存屏障(Memory Barrier,或有时叫做内存栅栏,Memory Fence)的方式来禁止特定类型的处理器重排序。指令并行重排和内存系统重排都属于是处理器级别的指令重排序。
64+
对于编译器优化重排和处理器的指令重排序(指令并行重排和内存系统重排都属于是处理器级别的指令重排序),处理该问题的方式不一样。
65+
66+
* 对于编译器,通过禁止特定类型的编译器重排序的方式来禁止重排序。
67+
68+
* 对于处理器,通过插入内存屏障(Memory Barrier,或有时叫做内存栅栏,Memory Fence)的方式来禁止特定类型的处理器重排序。
6569

6670
> 内存屏障(Memory Barrier,或有时叫做内存栅栏,Memory Fence)是一种 CPU 指令,用来禁止处理器指令发生重排序(像屏障一样),从而保障指令执行的有序性。另外,为了达到屏障的效果,它也会使处理器写入、读取值之前,将主内存的值写入高速缓存,清空无效队列,从而保障变量的可见性。
6771

0 commit comments

Comments
 (0)
Please sign in to comment.