回调函数 事件处理 dotnet .net 有界队列 背压机制(Backpressure)有界队列
通过有界队列来实现背压,确保生产者不会以超过消费者处理能力的速度发送数据。
using System.Threading.Channels;
public class Program
{
    static async Task Main(string[] args)
    {
        // 创建一个有界的消息队列,设置最大容量为5
        BoundedChannelOptions options = new BoundedChannelOptions(5)
        {
            FullMode = BoundedChannelFullMode.Wait, // 当队列满时,生产者等待
            SingleReader = true, // 该通道只有一个消费者
            SingleWriter = true // 该通道只有一个生产者
        };
        Channel<string> channel = Channel.CreateBounded<string>(options);
        // 启动消费者任务
        Task consumerTask = ConsumeMessagesAsync(channel.Reader);
        // 模拟生产者,尝试发送一些消息到队列
        while (true)
        {
            string? v = System.Console.ReadLine();
            if (!string.IsNullOrEmpty(v))
            {
                if (v == "q")
                {
                    channel.Writer.Complete();
                    await consumerTask;
                    break;
                }
                await WriteMessageAsync(channel.Writer, v);
                // Console.WriteLine($"Produced: {v}");
            }
        }
    }
    static async Task ConsumeMessagesAsync(ChannelReader<string> reader)
    {
        while (await reader.WaitToReadAsync())
        {
            while (reader.TryRead(out string item))
            {
                Console.WriteLine($"Consumed: {item}");
                await Task.Delay(100); // 模拟处理时间
            }
        }
    }
    static async Task WriteMessageAsync(ChannelWriter<string> writer, string message)
    {
        await writer.WriteAsync(message); // 生产者会在这里等待,直到有空间可用
    }
}
                    
                
                
                
            
        
浙公网安备 33010602011771号