如何同时/同步在特定的多核/处理器上运行多个任务

时间:2014-03-19 23:01:31

标签: c# multithreading parallel-processing task-parallel-library

我有多个任务,我需要同时在特定的多核或处理器上运行它们。

例如,如果我有两个不同的任务或只有一个任务但会运行两次我想同时在特定的核心或处理器上运行这两个任务,就像task1将在processor1上运行而task2将同时在processor2上运行

我知道如何运行每个特定的处理器,但我不知道如何同时运行它们。我试图使用多线程然后任务并行库同时在特定处理器上运行不同的任务,但我失败了。

在下面的代码中,我试图使用多线程但它不起作用或者我可以使用任务并行库???

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading;
using System.Diagnostics;


namespace ConsoleApplication14

{
    class Program
{

    public static double DumbCountSqr(int dumnum)
    {

        Random random = new Random();
        int randomNumber = random.Next(0, 10);
        double result = 0;
        for (int i = 1; i < 10000; i++)
        {
            for (int j = 1; j < 10000; j++)
            {
                result += random.Next(0, 10) * Math.Sqrt(i) * Math.Sqrt(j) + Math.Abs(Math.Sqrt(i));
            }
        }
        return result;
    }

    public static void Main()
    {

        Thread t = new Thread(new ThreadStart(Go));
        t.Start();


        for (int i = 0; i < 1; i++)
        {

            Process Proc = Process.GetCurrentProcess();
            long AffinityMask = (long)Proc.ProcessorAffinity;

            AffinityMask = 0x0004;//processor    3
            Proc.ProcessorAffinity = (IntPtr)AffinityMask;

            var result1 = DumbCountSqr(i);
            Console.WriteLine("result1 =  " + result1);

        }
    }


   public static void Go()
    {

        for (int i = 0; i < 1; i++)
        {

                Process Proc = Process.GetCurrentProcess();
                long AffinityMask = (long)Proc.ProcessorAffinity;

                AffinityMask = 0x0001;//processor    1
                Proc.ProcessorAffinity = (IntPtr)AffinityMask;

                var result2 = DumbCountSqr(i);
                Console.WriteLine("result2 =  " + result2);

        }

    }

}

}

1 个答案:

答案 0 :(得分:1)

使用任务并行库并查看Parallel.For方法。这可以利用多个核心。但要注意你是如何使用它的。并行循环可能并不总是比顺序循环更快。

以下是有关如何在MSDN上使用的示例:http://msdn.microsoft.com/en-us/library/dd460713(v=vs.110).aspx

在这里:http://msdn.microsoft.com/en-us/library/dd460703(v=vs.110).aspx

在这里:http://msdn.microsoft.com/en-us/library/ff963552.aspx