C# 并行编程
创始人
2024-05-02 14:51:24
0

一 并行任务库TPL

在这里插入图片描述

1 并行任务库(TPL,Task Parallel Library)

2 最重要的是Task类,还有Parallel类

3 Task类,是利用线程池来进行任务的执行

比如直接用ThreadPool更优化,而且编程更方便

4 Paallel类,是并行执行任务类的实用类

好处是可以隐式地实用Task,更方便。

二 Task类的使用

1 使用Task.Run方法来得到Task的实例

2 Tasktask=Task.Run()=>SomeFun());

3 可以使用Task.WaitAll(task数组)

4 可以使用task.ContinueWith(另一个task)

5 Task中的异常

可以使用AggregateException(合并的异常)

try
{Task.WaitAll(task1,task2,task3);
}
catch (AggregateException ex)
{foreach (Exception inner in ex.InnerException){Console.WriteLine("Exception type{0} from {1}",inner.GetType(),inner.Source);}
}

三 Parallel类的使用

Parallel.Invoke(Action[] actions);//并行执行多个任务,直到完成
Parallel.For(0,100,i>={…})
Parallel.ForEach(list,item=>{…})

四 并行Linq

1 并行Linq(即PLinq)

2 只要在集合上加个.AsParallel()

var a=(from n in persons.AsParallel()
where n.Age>20&&n.Age<25
select n)
.ToList();

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Threading;namespace 使用Task
{internal class Program{static void Main(string[] args){Task[] tasks ={Task.Run(()=>SomeFun()),Task.Run(()=>SomeFun()),};Thread.Sleep(1);for(int i=0;iConsole.WriteLine(tasks[i].Status);//可以查看状态Console.WriteLine(tasks[i].Result);//取Result时,会等到计算结束}Task.WaitAll(tasks);//也可以用这句,来等结束Console.ReadKey();}static void DoSometing() { }static double SomeFun() { Thread.Sleep(50);return 0; }}
}
using System;
using System.Collections.Generic;
using System.Diagnostics;
using System.Linq;
using System.Text;
using System.Threading.Tasks;namespace 并行计算矩阵乘法
{internal class Program{static void Main(string[] args){int m = 100, n = 400, t = 1000;double[,] ma = new double[m, n];double[,] mb = new double[n, t];double[,] r1 = new double[m, t];double[,] r2 = new double[m, t];InitMatrix(ma);InitMatrix(mb);InitMatrix(r1);InitMatrix(r2);Console.WriteLine("矩阵乘法");Stopwatch sw = new Stopwatch();sw.Start();MultiMatrixNormal(ma, mb, r1);sw.Stop();Console.WriteLine("普通方法用时" + sw.ElapsedMilliseconds);sw.Restart();MultiMatrixParallel(ma, mb, r2);sw.Stop();Console.WriteLine("并行方法用时" + sw.ElapsedMilliseconds);bool ok = CompareMatrix(r1, r2);Console.WriteLine("结果相同" + ok);Console.ReadKey();}static Random rnd = new Random();static void InitMatrix(double[,] matA){int m = matA.GetLength(0);int n = matA.GetLength(1);for (int i = 0; i < m; i++){for (int j = 0; j < n; j++){matA[i, j] = rnd.Next();}}}static void MultiMatrixNormal(double[,] matA, double[,] matB, double[,] result){int m = matA.GetLength(0);int n = matA.GetLength(1);int t = matB.GetLength(1);for (int i = 0; i < m; i++){for (int j = 0; j < t; j++){double temp = 0;for (int k = 0; k < n; k++){temp += matA[i, k] * matB[k, j];}result[i, j] = temp;}}}static void MultiMatrixParallel(double[,] matA, double[,] matB, double[,] result){int m = matA.GetLength(0);int n = matA.GetLength(1);int t = matB.GetLength(1);Parallel.For(0, m, i =>{for (int j = 0; j < t; j++){double temp = 0;for (int k = 0; k < n; k++){temp += matA[i, k] * matB[k, j];}result[i, j] = temp;}});}static bool CompareMatrix(double[,] matA,double[,] matB){int m = matA.GetLength(0);int n = matA.GetLength(1);for(int i=0;ifor(int j=0;jif (Math.Abs(matA[i, j] - matB[i, j]) > 0.1)return false;}}return true;}}
}

相关内容

热门资讯

保存时出现了1个错误,导致这篇... 当保存文章时出现错误时,可以通过以下步骤解决问题:查看错误信息:查看错误提示信息可以帮助我们了解具体...
汇川伺服电机位置控制模式参数配... 1. 基本控制参数设置 1)设置位置控制模式   2)绝对值位置线性模...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
表格中数据未显示 当表格中的数据未显示时,可能是由于以下几个原因导致的:HTML代码问题:检查表格的HTML代码是否正...
本地主机上的图像未显示 问题描述:在本地主机上显示图像时,图像未能正常显示。解决方法:以下是一些可能的解决方法,具体取决于问...
表格列调整大小出现问题 问题描述:表格列调整大小出现问题,无法正常调整列宽。解决方法:检查表格的布局方式是否正确。确保表格使...
不一致的条件格式 要解决不一致的条件格式问题,可以按照以下步骤进行:确定条件格式的规则:首先,需要明确条件格式的规则是...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...