欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C#并行庫Parallel類介紹

 更新時間:2022年06月16日 11:23:48   作者:天方  
這篇文章介紹了C#并行庫Parallel類,文中通過示例代碼介紹的非常詳細。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下

Parallel.Invoke

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

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

第二種方式可以自定義一個TaskManager對任務(wù)的執(zhí)行線程進行管理(第一種方式用的是默認的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);
}

輸出結(jié)果如下:

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

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

Parallel.ForEach和Parallel.For

Parallel.ForEach和Parallel.For用得要更加廣泛一些,他可以根據(jù)一個數(shù)據(jù)源來生成一些任務(wù)(Parallel.Invoke需要事先生成這些任務(wù)),同時并發(fā)執(zhí)行這些任務(wù)?;臼纠缦拢?/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]));
}

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

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);
        }
    }
}

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

到此這篇關(guān)于C#并行庫Parallel類的文章就介紹到這了。希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • C#中查找Dictionary中的重復(fù)值的方法

    C#中查找Dictionary中的重復(fù)值的方法

    這篇文章主要介紹了C#中查找Dictionary中的重復(fù)值的方法,需要的朋友可以參考下
    2015-09-09
  • c#構(gòu)造ColorComboBox(顏色下拉框)

    c#構(gòu)造ColorComboBox(顏色下拉框)

    這篇文章主要介紹了c#構(gòu)造ColorComboBox的代碼分享,大家參考使用吧
    2013-12-12
  • C#導(dǎo)出生成excel文件的方法小結(jié)(xml,html方式)

    C#導(dǎo)出生成excel文件的方法小結(jié)(xml,html方式)

    C#導(dǎo)出生成excel文件的方法小結(jié)(xml,html方式)。需要的朋友可以過來參考下,希望對大家有所幫助
    2013-10-10
  • C#基本打印事件用法實例

    C#基本打印事件用法實例

    這篇文章主要介紹了C#基本打印事件用法,實例分析了C#中print打印及DrawString文本字符串繪制等相關(guān)技巧,需要的朋友可以參考下
    2015-06-06
  • 關(guān)于C#反射 你需要知道的

    關(guān)于C#反射 你需要知道的

    這篇文章主要介紹了C#反射的相關(guān)知識,文中講解的非常詳細,代碼幫助大家更好的參考學(xué)習(xí),感興趣的朋友可以了解下
    2020-06-06
  • C#調(diào)用Oracle存儲過程的方法

    C#調(diào)用Oracle存儲過程的方法

    這篇文章主要介紹了C#調(diào)用Oracle存儲過程的方法,包含數(shù)據(jù)庫及C#對應(yīng)的調(diào)用代碼,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-01-01
  • C#使用NPOI操作Excel工具類的實現(xiàn)

    C#使用NPOI操作Excel工具類的實現(xiàn)

    NPOI是POI項目的.NET遷移版本,使用NPOI可以在沒有安裝Office或者相應(yīng)環(huán)境的機器上對Word或Excel文檔進行讀寫操作,下面我們就來學(xué)習(xí)一下如何使用NPOI編寫操作Excel的工具類吧
    2023-11-11
  • C#分屏控件用法實例

    C#分屏控件用法實例

    這篇文章主要介紹了C#分屏控件用法實例,需要的朋友可以參考下
    2014-08-08
  • C#操作Word打印的示例

    C#操作Word打印的示例

    這篇文章主要介紹了C#操作Word打印的示例,幫助大家利用c#打印文件,提高辦公效率,感興趣的朋友可以了解下
    2020-10-10
  • 深入理解C#之接口

    深入理解C#之接口

    這篇文章主要介紹了C#接口(Interface)用法,較為詳細的分析了C#中接口的功能、實現(xiàn)及使用技巧,具有一定參考借鑒價值,需要的朋友可以參考下
    2021-07-07

最新評論