var listInt3 = new List();
int length = 10000;
int n1 = 3000;
int n2 = 6000;
int n3 = 10000;
taskList.Add(Task.Run(() =>
{
for (int i = 0; i < n1; i++)
{
listInt1.Add(i);
}
}));
taskList.Add(Task.Run(() =>
{
for(int i = n1;i < n2; i++)
{
listInt2.Add(i);
}
}));
taskList.Add((Task)Task.Run(() =>
{
for (int i = n2; i < n3; i++)
{
listInt3.Add(i);
}
}));
Task.WaitAll(taskList.ToArray());
listInt1.AddRange(listInt2);
listInt1.AddRange(listInt3);
3.使用线程安全对象 看看数据结构 线程安全对象 List/Arraylist 都不是线程安全的集合–把list Arraylist 换成安全对象;
(1)BlockingCollection
// 创建 BlockingCollection 实例:
BlockingCollection ints = new BlockingCollection();
for (int i = 0; i < 10000; i++)
{
Task.Run(() =>
{
ints.Add(i);// 在生产者线程中,将数据添加到集合中
});
}
补充:
BlockingCollection 是 .NET 中提供的一个线程安全的集合类,用于在多线程环境中安全地传递和处理数据。它提供了一个简单而强大的机制,使得在生产者和消费者之间进行数据交换变得更加容易。
BlockingCollection boundedCollection = new BlockingCollection(capacity: 10); // 设置容量
当达到容量上限时,任何尝试向集合中添加元素的操作都将被阻塞,直到有消费者从集合中取走一些元素
BlockingCollection 采用生产者-消费者模型,并且在内部使用了信号量和锁等机制,以确保多线程环境中的线程安全性。它提供了一种阻塞式的操作,当集合为空时,消费者会被阻塞,当集合达到容量上限时,生产者也会被阻塞。
此外,BlockingCollection 还提供了其他一些方法,如TryAdd、TryTake等,以及可以传入 CancellationToken 进行取消操作的重载方法,使其更加灵活
(2)ConcurrentBag
ConcurrentBag ints = new ConcurrentBag();
for (int i = 0; i < 10000; i++)
{
Task.Run(() =>
{
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) {
// 遍历字典中的键值对
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数网络安全工程师,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年网络安全全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上网络安全知识点,真正体系化!
由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新
如果你觉得这些内容对你有帮助,可以添加VX:vip204888 (备注网络安全获取)
学习路线:
这个方向初期比较容易入门一些,掌握一些基本技术,拿起各种现成的工具就可以开黑了。不过,要想从脚本小子变成黑客大神,这个方向越往后,需要学习和掌握的东西就会越来越多以下是网络渗透需要学习的内容:
一个人可以走的很快,但一群人才能走的更远。不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
入门一些,掌握一些基本技术,拿起各种现成的工具就可以开黑了。不过,要想从脚本小子变成黑客大神,这个方向越往后,需要学习和掌握的东西就会越来越多以下是网络渗透需要学习的内容:
一个人可以走的很快,但一群人才能走的更远。不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
[外链图片转存中…(img-BEmRXKHo-1712474629677)]