2024年最全c# 高级编程-多线程安全_c# 多线程 数据安全(1),这些新技术你们都知道吗

写在最后

在结束之际,我想重申的是,学习并非如攀登险峻高峰,而是如滴水穿石般的持久累积。尤其当我们步入工作岗位之后,持之以恒的学习变得愈发不易,如同在茫茫大海中独自划舟,稍有松懈便可能被巨浪吞噬。然而,对于我们程序员而言,学习是生存之本,是我们在激烈市场竞争中立于不败之地的关键。一旦停止学习,我们便如同逆水行舟,不进则退,终将被时代的洪流所淘汰。因此,不断汲取新知识,不仅是对自己的提升,更是对自己的一份珍贵投资。让我们不断磨砺自己,与时代共同进步,书写属于我们的辉煌篇章。

需要完整版PDF学习资源私我

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化资料的朋友,可以点击这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

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) 操作的有力工具

以下是 ConcurrentStack 的基本用法:

创建 ConcurrentStack 实例

ConcurrentStack concurrentStack = new ConcurrentStack();

入栈操作:

// 在任意线程中

concurrentStack.Push(42); // 入栈

出栈操作:

// 在任意线程中

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数网络安全工程师,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年网络安全全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
img
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上网络安全知识点,真正体系化!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化资料的朋友,可以点击这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  • 23
    点赞
  • 23
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值