ints.Add(i);
});
}
补充:
ConcurrentBag 是 .NET 中提供的一个线程安全的集合类,用于在多线程环境中安全地存储和检索元素。与 BlockingCollection 不同,ConcurrentBag 不遵循生产者-消费者模型,而是允许多个线程同时进行添加和提取操作,因此它更适用于一些并发的场景。
基本用法
// 创建 ConcurrentBag 实例:
ConcurrentBag concurrentBag = new ConcurrentBag();
// 添加元素
// 在任意线程中
int data = GenerateData(); // 生成数据
concurrentBag.Add(data); // 将数据添加到集合中
// 提取元素
// 在任意线程中
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 {
// 队列为空
}
最后
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数网络安全工程师,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年网络安全全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上网络安全知识点!真正的体系化!
如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
WIDIl6X-1715800002721)]
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上网络安全知识点!真正的体系化!
如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!