大家读书读的非常仔细,感谢大家提供的勘误。明显错误的我整理到勘误表中了,一些建议或者语句不通顺的待商榷的保留在评论区,以后再出版的时候再斟酌
欢迎大家在评论区贴出你们的读书笔记!
# | 页码 | 错误描述 | 纠正建议 | 提交者 |
---|---|---|---|---|
3 | 原文: 但是对于并行编程模型,...的性能提升有时候是巨大的 | 建议: 但是对于并发编程模型,...的性能提升有时候是巨大的 | before80 | |
4 | 原文: 并且设计了对 线程更轻量级的协程 |
建议: 并且设计了比 线程更轻量级的协程 |
guowei-gong | |
5 | 原文: 底层的add函数体中,x / y |
建议: x + y |
chengxiaoer233 | |
16 | 原文: 需要将这些状态加载到集群 中 |
建议: 需要将这些状态加载到寄存器 中 |
skyjerry | |
25 | 原文: TestCounter例子的wg没有设置数量 | 建议: 在for循环外wg.Add(64) ,或者在for循环的第一行wg.Add(1) |
CZT0 | |
36 | 原文: mutexWaiterShift = iota // waiter开始的位, 3 |
建议: mutexWaiterShift = iota // waiter开始的位, 2 |
iofeqkurrc42 | |
38 | 原文: 图 2.10 第三列未加速 |
建议: 未加锁 |
iofeqkurrc42 | |
45 | 原文: 流程图第六行 "未加锁或饥饿状态 new +=1<<mutexWaiterShift" | 建议: "加锁或饥饿状态 new +=1<<mutexWaiterShift"。 其中的未加锁 要改成 加锁 |
illusionist-moon | |
47 | 原文: 也就是在 old 上加 muexLocked 锁标志 |
建议: 也就是在 old 上加 mutexLocked 锁标志 |
zzhaolei | |
51 | 原文: 然后第二个Unlock 的调用会被阻塞 |
建议: 然后第二个Lock 的调用会被阻塞 |
bswaterb | |
60 | 原文:token实现重入锁中的recursion字段 | 建议: 修改成atomic.Int64 |
songzhibin97 | |
61 | 原文: NewConcurrencyMap使用了可变参数size ...int |
建议: 不需要使用可变参数,修改为size int ,方法体中也需要做相应的检查和修改 |
shanliao420 | |
74 | 原文: 注意此时rw.readerWait 的值可能是负数 |
建议: 注意此时rw.readerCount 的值可能是负数 |
某读者 | |
124 | 原文: 7.1 线程安全的map | 建议: 7.1 内建map类型 | 随风遁隐 | |
182 | 原文: ServerHTTP(c context.Context w http.ResponseWriter, r *http.Request) |
建议: ServerHTTP(c context.Context, w http.ResponseWriter, r *http.Request) , 漏掉了参数的逗号分隔符 |
白明 | |
258 | 原文: var ch = make(chan int) |
建议: var ch = make(chan struct{}) |
白明 | |
230 | 原文: case v -> ch2: |
建议: case ch2 <- v: |
hoywu | |
270 | 原文: TryAcquire: 尝试请求 n 个资源。请求资源的阻塞方法 |
建议: TryAcquire: 尝试请求 n 个资源。请求资源的非阻塞方法 |
hoywu | |
323 | 原文: 第19章 Go并发编程和调度器 | 建议: 第19章 分布式并发原语 | 鸟窝、白明 | |
326 | 原文: 代表和 Redis 的会话 |
建议: 代表和 etcd 的会话 |
hoywu | |
before80 | 提供了一些段落更通顺的写法 | before80 |