ConcurrentDictionary 不能直接用 ContainsKey + thiskey 查值,因为两次调用间可能被其他线程修改,导致 KeyNotFoundException;应使用原子的 TryGetValue。ConcurrentDictionary 为啥不能直接用 ContainsKey + thiskey 查值因为两次调用之间可能被其他线程修改,ContainsKey 返回 true 后,thiskey 可能已不存在或值已变------这不是 bug,是并发下的正常竞态。正确做法是用 TryGetValue 一次完成判断和取值。TryGetValue 是原子操作,线程安全,推荐作为默认查值方式避免写 if (dict.ContainsKey(k)) var v = dictk;,这在高并发下会偶发 KeyNotFoundException如果要"有则更新、无则添加",优先用 AddOrUpdate,而不是先 TryGetValue 再手动 TryAddConcurrentQueue 的 TryDequeue 和 TryPeek 到底返回啥两者都返回 bool:成功为 true,失败(队列空)为 false;值通过 out T result 参数传出。注意:它们不阻塞,也不抛异常,空队列时只是静默返回 false。TryDequeue 移除并返回队首元素;TryPeek 仅查看不移除永远检查返回值,不要假设 out 参数一定被赋值(未成功时它可能是默认值)没有 Count 属性的实时性保证------Count 是快照值,多线程下可能立刻过期什么时候该用 ConcurrentDictionary,而不是加锁的普通 Dictionary不是"只要多线程就无脑换并发集合"。ConcurrentDictionary 内部用分段锁+无锁读,写入吞吐高,但单次操作开销比普通 Dictionary 大;且不支持枚举时修改(仍会抛 InvalidOperationException)。 文心快码 文心快码(Comate)是百度推出的一款AI辅助编程工具