C# System.Threading.Channels节流队列和采样队列,当消费者速度赶不上生产者时建议使用

using System;
using System.Threading.Channels;
using System.Threading.Tasks;
 
namespace ConsoleApp1
{
    class Program
    {
        static async Task Main(string[] args)
        {
            //==============================================节流队列==============================================
            //场景生产者比消费者运行得快,会造成不必要的内存使用,如希望保留所有的对象项,则建议使用节流队列
            Channel<int> queue = Channel.CreateBounded<int>(1);
            ChannelWriter<int> writer = queue.Writer;
            ChannelReader<int> reader = queue.Reader;
            await writer.WriteAsync(2);
            int result = 0;
            reader.TryRead(out result);
            Console.WriteLine($"reader {result}");
            //队列容量为1,则当里面有一个对象项的时候,需等待消费掉,下面的才能进队列
            await writer.WriteAsync(13);
            reader.TryRead(out result);
            Console.WriteLine($"reader {result}");
            writer.Complete();
 
            //==============================================采样队列==============================================
            //场景生产者比消费者运行得快,会造成不必要的内存使用,如需过滤保留的对象项(丢弃部分数据),则建议使用采样队列
            Channel<int> queue2 = Channel.CreateBounded<int>(new BoundedChannelOptions(1)
            {
                FullMode = BoundedChannelFullMode.DropOldest  //这里有四种模式,其中DropOldest丢弃最老的数据
            });
            ChannelWriter<int> writer2 = queue2.Writer;
            ChannelReader<int> reader2 = queue2.Reader;
            await writer2.WriteAsync(10);
            //下面操作会导致之前的10直接被丢弃掉
            await writer2.WriteAsync(100);
 
            reader2.TryRead(out int result2);
            Console.WriteLine($"reader2 {result2}");
 
            Console.ReadKey();
        }
    }
}

MSCL超级工具类库
基于C#开发的超强工具类,包含数据库操作,字符串处理,文件或者文件夹处理
网络请求,缓存处理,数据容器等上百个常用工具类封装,附带调用示例和参数说明,
提供CHM详细文档,上百个生产环境使用,稳定高效,简单易用。
真正做到“工具在手,一切尽有”,让你大幅度的提高编程效率,提高编程水平。
联系QQ:7400799(请备注 "MSCL")

===============================================

重要压缩文件忘记解压密码?网上下载rar/zip/7z等压缩文件,需要密码?
====极速解密助手,支持支持RAR/ZIP/7Z等多种压缩文档解密======
★ 解密不超过24小时,跟密码复杂程度相关
★ 解密成功后再收费,无套路
★ 解密成功后自动删除原件,无后顾之忧
联系QQ:7400799(请备注 "文件解密")

==============================================

Magic.Orm已在数百个成熟项目中应用,是比较完善的ORM框架(基于C#开发)。开发过程中参考了NBear与MySoft,吸取了其中的一些精华,加入新思想,
后期参考EF的Lambda语法进行大量扩展。

为什么选择Magic.Orm?

  • 上手简单,0学习成本。使用方便,按照sql书写习惯编写C#.NET代码。功能强大。
  • 高性能,接近手写Sql。
  • 体积小(不到200kb,仅一个dll)。
  • 完美支持Sql Server(2000至最新版),MySql,Oracle,Access,Sqlite等数据库。
  • 支持大量Lambda表达式写法。
  • 不需要像NHibernate的XML配置,不需要像EF的各种数据库连接驱动,集成简单。

购买源码 请联系QQ:7400799(请备注 "ORM")

原文地址:https://www.cnblogs.com/smartsmile/p/14415976.html