如何在.NET中实现具有尺寸限制的线程安全阻塞队列?
.NET 中的线程安全阻塞队列
在多线程同时访问队列进行读写操作的场景中,控制队列大小对于防止队列无限增长至关重要。本文讨论在 .NET 中创建自定义阻塞队列实现的方法。
一个简单的方案是使用集合作为队列的基础,并使用 AutoResetEvent
(_FullEvent) 在队列达到指定最大大小 (MaxSize) 时阻塞添加线程。移除项目时,发出 _FullEvent 信号以允许入队。
然而,由于同步不足,这种实现的安全性令人担忧。改进的方法是利用标准化的队列类型,并使用同步基元显式管理阻塞。
以下代码展示了改进后的实现:
class SizeQueue<T> { private readonly Queue<T> queue = new Queue<T>(); private readonly int maxSize; public SizeQueue(int maxSize) { this.maxSize = maxSize; } public void Enqueue(T item) { lock (queue) { while (queue.Count >= maxSize) { Monitor.Wait(queue); } queue.Enqueue(item); if (queue.Count == 1) { // 唤醒任何被阻塞的出队操作 Monitor.PulseAll(queue); } } } public T Dequeue() { lock (queue) { while (queue.Count == 0) { Monitor.Wait(queue); } T item = queue.Dequeue(); if (queue.Count == maxSize - 1) { // 唤醒任何被阻塞的入队操作 Monitor.PulseAll(queue); } return item; } } }
此实现通过使用内置同步结构提供了一种安全高效的限制队列大小的机制。此外,它还包括优雅地关闭队列的功能,允许读取器干净地退出。
bool closing; public void Close() { lock(queue) { closing = true; Monitor.PulseAll(queue); } } public bool TryDequeue(out T value) { lock (queue) { while (queue.Count == 0) { if (closing) { value = default(T); return false; } Monitor.Wait(queue); } value = queue.Dequeue(); if (queue.Count == maxSize - 1) { // 唤醒任何被阻塞的入队操作 Monitor.PulseAll(queue); } return true; } }
以上是如何在.NET中实现具有尺寸限制的线程安全阻塞队列?的详细内容。更多信息请关注PHP中文网其他相关文章!

热AI工具

Undress AI Tool
免费脱衣服图片

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

获取std::vector的第一个元素有四种常用方法:1.使用front()方法,需确保vector非空,语义清晰且推荐日常使用;2.使用下标[0],同样需判空,性能与front()相当但语义稍弱;3.使用*begin(),适用于泛型编程和STL算法配合;4.使用at(0),无需手动判空但性能较低,越界时抛出异常,适合调试或需要异常处理的场景;最佳实践是先调用empty()检查是否为空,再使用front()方法获取第一个元素,避免未定义行为。

要判断std::optional是否有值,可使用has_value()方法或直接在if语句中判断;返回可能为空的结果时推荐使用std::optional,避免空指针和异常;不应滥用,某些场景下布尔返回值或独立bool变量更合适;初始化方式多样,但需注意使用reset()清空值,并留意生命周期和构造行为。

RAII是C 中用于资源管理的重要技术,其核心在于通过对象生命周期自动管理资源。它的核心思想是:资源在构造时获取,在析构时释放,从而避免手动释放导致的泄漏问题。例如,在没有RAII时,文件操作需手动调用fclose,若中途出错或提前return就可能忘记关闭文件;而使用RAII后,如FileHandle类封装文件操作,离开作用域后会自动调用析构函数释放资源。1.RAII应用于锁管理(如std::lock_guard)、2.内存管理(如std::unique_ptr)、3.数据库和网络连接管理等

函数是C 中组织代码的基本单元,用于实现代码重用和模块化;1.函数通过声明和定义创建,如intadd(inta,intb)返回两数之和;2.调用函数时传递参数,函数执行后返回对应类型的结果;3.无返回值函数使用void作为返回类型,如voidgreet(stringname)用于输出问候信息;4.使用函数可提高代码可读性、避免重复并便于维护,是C 编程的基础概念。

C 标准库通过提供高效工具帮助开发者提升代码质量。 1.STL容器应根据场景选择,如vector适合连续存储,list适合频繁插入删除,unordered_map适合快速查找;2.标准库算法如sort、find、transform能提高效率并减少错误;3.智能指针unique_ptr和shared_ptr有效管理内存,避免泄漏;4.其他工具如optional、variant、function增强代码安全性与表达力。掌握这些核心功能可显着优化开发效率与代码质量。

删除元素时若正在迭代,必须避免使用失效迭代器。①正确做法是使用it=vec.erase(it),利用erase返回的有效迭代器继续遍历;②批量删除推荐“erase-remove”惯用法:vec.erase(std::remove_if(vec.begin(),vec.end(),条件),vec.end()),安全且高效;③可使用反向迭代器从后往前删除,逻辑清晰但需注意条件方向。结论:始终用erase返回值更新迭代器,禁止对已失效迭代器执行 操作,否则导致未定义行为。

C foldexpressions是C 17引入的特性,用于简化可变参数模板中的递归操作。1.左折叠(args ...)从左到右求和,如sum(1,2,3,4,5)返回15;2.逻辑与(args&&...)判断所有参数是否为真,空包返回true;3.使用(std::cout
