CLR via C#中的一个多线程例子

时间:2023-03-09 06:24:21
CLR via C#中的一个多线程例子

parallel的For和ForEach方法有一些重载版本允许传递三个委托

1.任务局部初始化委托(localInit),未参与工作的每一个任务都调用一次委托,在任务被要求处理前调用。

2.主体委托(body),为参与工作的各个线程锁处理的酶一项都调用一次该委托。

3.任务局部终结委托(localFinially),为参与工作的每一个任务都调用一次委托。这个委托实在任务处理好派遣给它的所有工作项之后调用的。即使主体委托代码引发的  一个未处理的异常,也会调用它。

演示如何利用三个委托,计算目录中所有文件的长度值。

            long masterTotal = 0;              //文件中长度,初始化为0 

var files = Directory.GetFiles(@"C:\Users\zhang\Desktop\新建文件夹");

             ParallelLoopResult result = Parallel.ForEach<string, Int64>(files,

() => {    //每个人物开始之前条用一次

//每个任务开始之前,总计值都初始化为0

return 0; },

(file, loopSate, index, taskLocalTotal) =>

{

Int64 filelength = 0;

FileStream fs = null;

try

{

fs = File.OpenRead(file);

filelength = fs.Length;

}

catch

{

//忽略拒接访问的文件
                    }

finally

{

if (fs != null)

fs.Dispose();

}

return taskLocalTotal + filelength;

},

taskLocalTotal =>

{

//每个人物完成时调用一次

//将这个人物的总计,加到总的总计上

Interlocked.Add(ref masterTotal, taskLocalTotal);

});

Console.WriteLine(masterTotal);
            Console.ReadLine();

输出结果是:

单位字节

CLR via C#中的一个多线程例子