// 在任意线程中
if (concurrentBag.TryTake(out int data)) {
// 成功从集合中获取数据
} else {
// 集合为空
}
TryTake 方法是非阻塞的,如果集合为空,它会返回 false。
// 适用于多线程环境:
ConcurrentBag 内部使用了一些并发安全的技术,允许多个线程同时进行添加和提取操作,而不需要显式的锁或同步机制。
// 不保证元素的顺序:
ConcurrentBag 不保证元素的顺序,因此对于不要求顺序的场景,它是一个高效的选择。
总结:需要注意的是,ConcurrentBag 不支持对集合进行修改的操作,例如删除指定元素等。它主要用于在多线程环境中安全地进行添加和提取操作。如果你需要支持更多的集合操作,可能需要考虑其他实现了 ICollection 接口的线程安全集合,比如 ConcurrentQueue 或 ConcurrentDictionary<TKey, TValue>。
总体而言,ConcurrentBag 提供了一种在多线程环境中安全地处理元素的方式,特别适用于不要求特定顺序的场景。
(3)ConcurrentDictionary
ConcurrentDictionary<TKey, TValue> 是 .NET 中提供的一个线程安全的字典集合。它允许多个线程同时对字典进行读取和写入操作,而不需要显式的锁定。这使得它成为在多线程环境中安全地管理键值对数据的有力工具。
以下是 ConcurrentDictionary<TKey, TValue> 的基本用法:
// 创建 ConcurrentDictionary<TKey, TValue> 实例:
ConcurrentDictionary<string, int> concurrentDictionary = new ConcurrentDictionary<string, int>();
// 添加或更新元素:
// 在任意线程中
concurrentDictionary.TryAdd(“Key1”, 42); // 添加键值对
concurrentDictionary[“Key2”] = 99; // 或者使用索引器语法直接赋值
// 获取元素
// 在任意线程中
if (concurrentDictionary.TryGetValue(“Key1”, out int value)) {
// 成功获取值
} else {
// 键不存在
}
// 移除元素
// 在任意线程中
concurrentDictionary.TryRemove(“Key1”, out int removedValue); // 移除键值对
// 遍历字典
// 在任意线程中
foreach (var kvp in concurrentDictionary) {
// 遍历字典中的键值对
}
// 原子性的更新操作
// 在任意线程中
concurrentDictionary.AddOrUpdate(“Key1”, 1, (key, existingValue) => existingValue + 1);
AddOrUpdate 方法允许你执行原子性的更新操作,即使在多线程环境中,也能保证逻辑的一致性。
总结:ConcurrentDictionary<TKey, TValue> 提供了在多线程环境中进行字典操作的简便方法,而无需显式的线程同步。它的性能在并发读取和写入方面较好,适用于高度并发的场景。
需要注意的是,虽然 ConcurrentDictionary<TKey, TValue> 对于大多数情况下的并发操作是足够的,但在某些特殊情况下,可能需要额外的同步或锁定。此外,如果需要按照特定顺序访问字典的键值对,可能需要考虑其他有序字典的实现。
(4)ConcurrentQueue
ConcurrentQueue 是 .NET 中提供的一个线程安全的队列实现。它允许多个线程同时进行入队和出队操作,而不需要显式的锁定。这使得它成为在多线程环境中安全地进行先进先出 (FIFO) 操作的有力工具。
以下是 ConcurrentQueue 的基本用法:
创建 ConcurrentQueue 实例:
ConcurrentQueue concurrentQueue = new ConcurrentQueue();
入队操作
// 在任意线程中
concurrentQueue.Enqueue(42); // 入队
出队操作
// 在任意线程中
if (concurrentQueue.TryDequeue(out int value)) {
// 成功出队
} else {
// 队列为空
}
TryDequeue 方法是非阻塞的,如果队列为空,它会返回 false。
查看队列头部元素而不移除:
// 在任意线程中
if (concurrentQueue.TryPeek(out int peekedValue)) {
// 成功查看队列头部元素
} else {
// 队列为空
}
判断队列是否为空:
// 在任意线程中
bool isEmpty = concurrentQueue.IsEmpty;
// 遍历队列
// 在任意线程中
foreach (var item in concurrentQueue) {
// 遍历队列中的元素
}
总结:ConcurrentQueue 是基于锁-free技术实现的,并在内部使用了 CAS (Compare-and-Swap) 操作,以确保多线程环境下的线程安全。它适用于需要在多个线程之间共享数据,且希望通过队列的方式实现安全、高效的数据传递的场景。
需要注意的是,ConcurrentQueue 的元素遵循先进先出 (FIFO) 的原则,因此保持了插入顺序。如果需要其他排序方式,可能需要考虑其他的并发集合,比如 ConcurrentBag 或 ConcurrentDictionary<TKey, TValue>。
(5)ConcurrentStack
ConcurrentStack 是 .NET 中提供的一个线程安全的栈实现。与 ConcurrentQueue 类似,ConcurrentStack 允许多个线程同时进行入栈和出栈操作,而不需要显式的锁定。这使得它成为在多线程环境中安全地进行后进先出 (LIFO) 操作的有力工具
最后
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数网络安全工程师,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年网络安全全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上网络安全知识点!真正的体系化!
如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
qsGib3u-1715800064832)]
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上网络安全知识点!真正的体系化!
如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!