首页 > 代码库 > CLR via C#中的一个多线程例子

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#中的一个多线程例子