欧美成人精品手机在线观看_69视频国产_动漫精品第一页_日韩中文字幕网 - 日本欧美一区二区

LOGO OA教程 ERP教程 模切知識交流 PMS教程 CRM教程 開發文檔 其他文檔  
 
網站管理員

C# 中限制并發任務數量的高效方法與技巧

admin
2024年12月23日 19:48 本文熱度 117

引言

在 C# 開發中,合理控制并發任務數量是確保應用程序高效、穩定運行的關鍵。過多的并發任務可能會耗盡系統資源,導致性能下降和不穩定。本文將深入探討幾種有效的方法來限制 C# 中的并發任務數量,并通過具體的應用場景和示例代碼展示如何實現這些方法。

使用 SemaphoreSlim

SemaphoreSlim 是一個輕量級的同步原語,用于控制訪問某一資源或資源池的線程數。通過它,我們可以很容易地限制并發任務的數量。當你有一個需要訪問共享資源(如數據庫連接池)的任務列表,但希望同時執行的任務數量不超過某個特定值時,可以使用SemaphoreSlim。

示例

using System;
using System.Collections.Generic;
using System.Threading;
using System.Threading.Tasks;

class Program
{
    static async Task Main(string[] args)
    {
        int maxConcurrentTasks = 3;
        SemaphoreSlim semaphore = new SemaphoreSlim(maxConcurrentTasks);
        List<Task> tasks = new List<Task>();
        for (int i = 0; i < 100; i++)
        {
            await semaphore.WaitAsync();
            var task = Task.Run(async () =>
            {
                try
                {
                    // 模擬長時間運行的任務
                    Console.WriteLine($"Task {Task.CurrentId} started.");
                    await Task.Delay(TimeSpan.FromSeconds(2));
                    Console.WriteLine($"Task {Task.CurrentId} completed.");
                }
                finally
                {
                    semaphore.Release();
                }
            });
            tasks.Add(task);
        }
        await Task.WhenAll(tasks);
        Console.WriteLine("All tasks completed.");
    }
}

在這個示例中,我們限制了最多只有 3 個任務可以同時運行。通過對SemaphoreSlim 的調用,我們確保了當達到最大并發任務數量時,其他任務將會等待直到某個任務完成并釋放信號量。

使用 TPL Dataflow

TPL (Task Parallel Library) Dataflow 提供了一個更高級的方式來處理數據流和并發任務,通過它可以很容易地限制并發任務的數量。當你需要處理一系列的數據或任務,并且每個任務都可能需要一些時間來完成,同時你想要限制同時處理這些任務的數量時,可以使用 TPL Dataflow。

示例

using System;
using System.Threading.Tasks;
using System.Threading.Tasks.Dataflow;

class Program
{
    static async Task Main(string[] args)
    {
        var options = new ExecutionDataflowBlockOptions
        {
            MaxDegreeOfParallelism = 3 // 最大并發任務數量
        };
        var block = new ActionBlock<int>(async n =>
        {
            Console.WriteLine($"Processing {n}...");
            await Task.Delay(TimeSpan.FromSeconds(1)); // 模擬異步操作
            Console.WriteLine($"Processed {n}.");
        }, options);
        for (int i = 0; i < 100; i++)
        {
            block.Post(i);
        }
        block.Complete();
        await block.Completion;
        Console.WriteLine("All tasks completed.");
    }
}

在這個示例中,ActionBlock 被用來處理一系列的任務,通過設置ExecutionDataflowBlockOptions 中的MaxDegreeOfParallelism 屬性,我們限制了最大的并發任務數量。

使用 Parallel.ForEach

Parallel.ForEach 是 .NET 中用于并行處理集合元素的方法,它可以指定MaxDegreeOfParallelism 參數來限制并發任務的數量。

示例

using System;
using System.Collections.Generic;
using System.Threading.Tasks;

class Program
{
    static async Task Main(string[] args)
    {
        var urls = new List<string> { /* 一系列 URL */ };
        var options = new ParallelOptions { MaxDegreeOfParallelism = 3 };
        await Parallel.ForEachAsync(urls, options, async (url, _) =>
        {
            var html = await new HttpClient().GetStringAsync(url);
            Console.WriteLine($"retrieved {html.Length} characters from {url}");
        });
    }
}

在這個示例中,我們使用Parallel.ForEachAsync 方法來并行下載多個網頁內容,并通過設置MaxDegreeOfParallelism 為 3 來限制同時進行的下載任務數量。

使用 Polly Bulkhead

Polly 是一個強大的 .NET 錯誤處理和彈性庫,它的 Bulkhead 隔板策略可以限制并發任務的數量,并可以選擇將超過該數量的任務排隊。

示例

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Threading.Tasks;
using Polly;

class Program
{
    static async Task Main(string[] args)
    {
        var bulkhead = Policy.BulkheadAsync(3, Int32.MaxValue); // 最大并發任務數量為 3
        var urls = new List<string> { /* 一系列 URL */ };
        var tasks = new List<Task>();
        foreach (var url in urls)
        {
            var t = bulkhead.ExecuteAsync(async () =>
            {
                var html = await new HttpClient().GetStringAsync(url);
                Console.WriteLine($"retrieved {html.Length} characters from {url}");
            });
            tasks.Add(t);
        }
        await Task.WhenAll(tasks);
    }
}

在這個示例中,我們使用 Polly 的 Bulkhead 隔板策略來限制并發下載任務的數量,并將超過最大并發數量的任務自動排隊。

使用 Task.WhenAny

Task.WhenAny 方法可以用于限制并發任務的數量,其基本思路是維護一個任務列表,當任務數量達到閾值時,等待其中一個任務完成,然后繼續添加新任務。

示例

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Threading.Tasks;

class Program
{
    static async Task Main(string[] args)
    {
        var urls = new List<string> { /* 一系列 URL */ };
        var maxConcurrentTasks = 3;
        var tasks = new List<Task>();
        foreach (var url in urls)
        {
            tasks.Add(Task.Run(async () =>
            {
                var html = await new HttpClient().GetStringAsync(url);
                Console.WriteLine($"retrieved {html.Length} characters from {url}");
            }));
            if (tasks.Count >= maxConcurrentTasks)
            {
                await Task.WhenAny(tasks);
                tasks = tasks.Where(t => t.Status == TaskStatus.Running).ToList();
            }
        }
        await Task.WhenAll(tasks);
    }
}

在這個示例中,我們通過Task.WhenAny 方法來等待任務列表中的任意一個任務完成,然后移除已完成的任務,從而保持并發任務的數量不超過閾值。

總結

限制并發任務的數量是確保應用程序穩定和高效運行的關鍵。在 C# 中,我們可以使用SemaphoreSlim、TPL Dataflow、Parallel.ForEach、Polly Bulkhead 和Task.WhenAny 等多種方法來輕松實現這一目標。根據具體的業務需求和應用場景,選擇最合適的方法來控制并發任務的數量,可以有效避免資源過度消耗,提高系統的響應速度和可靠性。


該文章在 2024/12/24 11:48:49 編輯過
關鍵字查詢
相關文章
正在查詢...
點晴ERP是一款針對中小制造業的專業生產管理軟件系統,系統成熟度和易用性得到了國內大量中小企業的青睞。
點晴PMS碼頭管理系統主要針對港口碼頭集裝箱與散貨日常運作、調度、堆場、車隊、財務費用、相關報表等業務管理,結合碼頭的業務特點,圍繞調度、堆場作業而開發的。集技術的先進性、管理的有效性于一體,是物流碼頭及其他港口類企業的高效ERP管理信息系統。
點晴WMS倉儲管理系統提供了貨物產品管理,銷售管理,采購管理,倉儲管理,倉庫管理,保質期管理,貨位管理,庫位管理,生產管理,WMS管理系統,標簽打印,條形碼,二維碼管理,批號管理軟件。
點晴免費OA是一款軟件和通用服務都免費,不限功能、不限時間、不限用戶的免費OA協同辦公管理系統。
Copyright 2010-2025 ClickSun All Rights Reserved