目录前言BlockinGCollection简单介绍起手式接下来进入实际使用场景场景一: 生产者=> 消费者场景二: 实现队列FIFO(先进先出),LIFO(先进后出)前言 如
如果你想玩转C# 里面多线程,工厂模式,生产者/消费者,队列等高级操作,就可以和我一起探索这个强大的线程安全提供阻塞和限制功能的C#神器类
微软介绍地址:https://learn.microsoft.com/zh-cn/dotnet/standard/collections/thread-safe/blockingcollection-overviewBlockingCollection 是一个线程安全集合类,可提供以下功能:
BlockingCollection blockingCollection = new(1);
new 操作符里面的数字是实现了可选最大容量,超出就线程阻塞了,程序一直卡在哪里
先来个开胃菜 => 三句代码实现线程阻塞
BlockingCollection<int> blockingCollection = new(1);
blockingCollection.Add(1);
blockingCollection.Add(2);
说明:因为限制队列只能插入一条,第一条没有消费掉,所以一直卡在插入第二条程序不会往下继续运行实现了集合为空或已满时通过插入和移除操作进行阻塞
正式开始前先分享一些多线程的知识点
Task类简单介绍
Task 表面上是Thread但却是对ThreadPool的封装,控制和扩展性很强,对线程的延续,阻塞,取消,超时,比传统的Thread和ThreadPool强
Queue类简单介绍
队列(Queue)代表了一个先进先出的对象集合。当您需要对各项进行先进先出的访问时,则使用队列。当您在列表中添加一项,称为入队,当您从列表中移除一项时,称为出队
建议代码还是要动手实现一下,不然体会不到一边生产数据,同时还能取数据的神仙操作
int count = 0 ;
BlockingCollection<string> blockingCollection = new(1);
//生产者
Task.Factory.StartNew(() =>
{
while (true)
{
blockingCollection.Add("String: " + count);
count++;
if (count > 10)
{
blockingCollection.CompleteAdding();
}
}
});
//消费者
Task.Factory.StartNew(() =>
{
foreach (var element in blockingCollection.GetConsumingEnumerable())
{
Thread.Sleep(1000);
("Work: " + element).Dump();//Dump 为工具Linq的功能
}
});
上面的代码中这个方法GetConsumingEnumerable
很重要,它可以在BlockingCollection集合有数据的时候取数据,没有的话停止取,可以达到监测的效果
这个案例实现了如下功能:
生产者/消费者输出结果
Work: String: 0
Work: String: 1
Work: String: 2
Work: String: 3
Work: String: 4
Work: String: 5
Work: String: 6
Work: String: 7
Work: String: 8
Work: String: 9
Work: String: 10
//先进先出(FIFO)
BlockingCollection<int> bc = new(new ConcurrentQueue<int>());
bc.Add(1);
bc.Add(2);
bc.CompleteAdding();
//先进后出(LIFO)
BlockingCollection<int> bc2 = new(new ConcurrentStack<int>());
bc2.Add(1);
bc2.Add(2);
bc2.CompleteAdding();
bc.Take().Dump("bc1:");
bc2.Take().Dump("bc2:");
队列输出结果
bc :1
bc2: 2
这个简单的案例是想介绍一下其实:BlockingCollection也可以实现队列的功能
到此这篇关于C#中神器类BlockingCollection的实现详解的文章就介绍到这了,更多相关C# BlockingCollection内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!
--结束END--
本文标题: C#中神器类BlockingCollection的实现详解
本文链接: https://lsjlt.com/news/197791.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
2024-03-01
2024-03-01
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0