溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

C#并行庫Parallel類怎么使用

發布時間:2022-06-16 14:06:36 來源:億速云 閱讀:168 作者:iii 欄目:開發技術

本篇內容主要講解“C#并行庫Parallel類怎么使用”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“C#并行庫Parallel類怎么使用”吧!

Parallel.Invoke

這個函數的功能和Task有些相似,就是并發執行一系列任務,然后等待所有完成。和Task比起來,省略了Task.WaitAll這一步,自然也缺少了Task的相關管理功能。它有兩種形式:

Parallel.Invoke( params Action[] actions);
Parallel.Invoke(Action[] actions,TaskManager manager,TaskCreationOptions options);

第二種方式可以自定義一個TaskManager對任務的執行線程進行管理(第一種方式用的是默認的TaskManager.Default)。

示例如下:

static void Main(string[] args)
{
    var actions = new Action[]{
        () => ActionTest("test 1"),
        () => ActionTest("test 2"),
        () => ActionTest("test 3"),
        () => ActionTest("test 4")};

    Console.WriteLine("Parallel.Invoke 1 Test");
    Parallel.Invoke(actions);

    Console.WriteLine();

    Console.WriteLine("Parallel.Invoke 2 Test");
    Parallel.Invoke(actions, new TaskManager(new TaskManagerPolicy(1, 1, 2)), TaskCreationOptions.None);
}

static void ActionTest(object value)
{
    Console.WriteLine(">>> thread:{0}, value:{1}",
    Thread.CurrentThread.ManagedThreadId, value);
}

輸出結果如下:

Parallel.Invoke 1 Test
>>> thread:3, value:test 1
>>> thread:3, value:test 2
>>> thread:4, value:test 3
>>> thread:5, value:test 4

Parallel.Invoke 2 Test
>>> thread:7, value:test 1
>>> thread:7, value:test 2
>>> thread:8, value:test 3
>>> thread:7, value:test 4

可見,由于第二次指定了最多只能使用兩個線程來執行,故只有兩個Task并發執行。

Parallel.ForEach和Parallel.For

Parallel.ForEach和Parallel.For用得要更加廣泛一些,他可以根據一個數據源來生成一些任務(Parallel.Invoke需要事先生成這些任務),同時并發執行這些任務?;臼纠缦拢?/p>

static void Main(string[] args)
{
    var data = new object[] { "test 1", "test 2", "test 3" };

    Console.WriteLine("Parallel.ForEach Test");
    Parallel.ForEach(data, item => ActionTest(item));

    Console.WriteLine();

    Console.WriteLine("Parallel.For Test");
    Parallel.For(0, data.Length, index => ActionTest(data[index]));
}

這兩個函數都有多種重載形式,提供了許多控制功能,由于用得不是很多,這里就不一一介紹了。但有一點不是很好:如果需要用TaskManager的話,不得不用那最復雜的那一種形式。希望最終版本的時候會提供更合理的重載形式,畢竟TaskManager還是很常用的(雖然目前的TaskManager功能薄弱了點),而那些復雜的參數不是很常用的。因此,這里提供了兩個常用的擴展方法的封裝:

public static class ParallelExtend
{
    public static void ParallelForEach<T>(this IEnumerable<T> source, Action<T> hanlder)
    {
        Parallel.ForEach(source, hanlder);
    }

    public static void ParallelForEach<T>(this IEnumerable<T> source, Action<T> hanlder, TaskManagerPolicy policy)
    {
        using (var manager = new TaskManager(policy))
        {
            Parallel.ForEach(source,
                () => 0,
                (item, index, state) => hanlder(item),
                local => { },
                manager,
                TaskCreationOptions.None);
        }
    }
}

通過擴展方法的方式用起來還是比較方便的。

到此,相信大家對“C#并行庫Parallel類怎么使用”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女