我这里针对现有的C#多线程技术进行一个汇总,一是复习,二是方便索引,文章部份知识点来源于网络,非本人原创。

一、并行(异步):

1.System.Threading.Tasks命名空间下的(TPL):

1.1:Parallel.Invoke --并行执行多个任务,主线程等待并行执行完毕后才开始续续运行。

示例:

        static void Main(string[] args)
{
Parallel.Invoke(new ParallelOptions() { MaxDegreeOfParallelism=2},Run1,Run2);
Console.WriteLine("我是主线程!");
Console.Read();
} static void Run1()
{
Console.WriteLine("我是任务一,我运行3s");
Thread.Sleep(3000);
Console.WriteLine("任务一执先完成");
} static void Run2()
{
Console.WriteLine("我是任务二,我运行5s");
Thread.Sleep(5000);
Console.WriteLine("任务二执先完成");
}

1.2:Parallel.For--循环迭代多个任务,多个任务之间存在并行情况,主线程等待循环迭代的多个任务执行完毕后才开始续续运行。

示例:

Parallel.For(0, 10, (i) => {
Console.WriteLine("我是第{0}个任务,线程ID是:{1}",i,Thread.CurrentThread.ManagedThreadId);
Thread.Sleep(new Random().Next(10) * 10 * 500);
Console.WriteLine("线程ID是:{0}执行完成", Thread.CurrentThread.ManagedThreadId);
});

1.3:Parallel.ForEach--循环迭代多个任务,多个任务之间存在并行情况,主线程等待循环迭代的多个任务执行完毕后才开始续续运行。注意它有多个重载方法

示例:

            var bag = new ConcurrentBag<int>();

            Parallel.ForEach(Partitioner.Create(0, 100), i =>
{
for (int m = i.Item1; m < i.Item2; m++)
{
bag.Add(m);
Console.WriteLine("我是第{0}个任务,线程ID是:{1}", m, Thread.CurrentThread.ManagedThreadId);
}
});
Console.WriteLine("并行计算:集合有:{0}", bag.Count);

1.4:TAP(基于任务的异步编),使用Task类 (注意:默认任务开启后,会在新线程中执行,主线程不会等待任务而是继续下面的执行,若使用Task.WaitAll,则会等待相应的任务完成后才会执行)

示例:

//第一种方式启动
var task1 = new Task(() => //实例化
{
Run1();
}); task1.Start(); //启动 //第二种方式开启
var task2 = Task.Factory.StartNew(() => //直接创建任务并启动
{
Run2();
}); //主线程等待任务执行完
Task.WaitAll(task1, task2);

2.ParallelEnumerable类中的扩展方法(先将枚举对象使用AsParallel转换成ParallelQuery类型,然后就可以使用ParallelQuery在ParallelEnumerable类相关的扩展方法)

示例:

var resultList = testList.AsParallel().Where(i=>i>=100).ToList();
Console.WriteLine("resultList Count:{0}", resultList.Count);

3.创建新Thread--新线程启动后,主线程与创建的线程各自执行,若需要主线程等待异步线程执行完成后才执行,则应使用asyncThread.Join方法。

示例:

        static void AsyncThreadMethod()
{
Console.WriteLine("我是异步执行线程,线程ID是:{0}", Thread.CurrentThread.ManagedThreadId);
} static void AsyncThreadMethod(object state)
{
Console.WriteLine("我是异步执行线程,线程ID是:{0},状态:{1}", Thread.CurrentThread.ManagedThreadId,state);
} //创建线程并执行
Thread asyncThread = new Thread(new ThreadStart(AsyncThreadMethod));
asyncThread.IsBackground = true;
asyncThread.Start(); Thread asyncThread2 = new Thread(new ParameterizedThreadStart(AsyncThreadMethod));
asyncThread2.IsBackground = true;
asyncThread2.Start("这是来自主线程的参数");

4.使用ThreadPool.QueueUserWorkItem静态方法--WaitCallback回调方法要求其必需带一个object的参数

示例:

 ThreadPool.QueueUserWorkItem(new WaitCallback(AsyncThreadMethod));//不带参数,则系统将state自动设为null

ThreadPool.QueueUserWorkItem(new WaitCallback(AsyncThreadMethod), "这是来自主线程的参数");

5.APM(异步编程模型),利用BeginInvoke与EndInvoke完成异步执行委托方法

示例:

            Func<string, string> funcDelegate = (s) =>
{
Console.WriteLine("我是Func委托方法!");
return "委托方法参数:" + s;
}; //1.无阻塞异步回调
var aysncResult = funcDelegate.BeginInvoke("这是来自主线程的参数", new AsyncCallback((result) =>
{
//获取委托对象,调用EndInvoke方法获取运行结果
AsyncResult _result = (AsyncResult)result;
var func = (Func<string, string>)_result.AsyncDelegate;
string data = func.EndInvoke(_result);
Console.WriteLine(data +",附加参数:" + _result.AsyncState.ToString());
}),"其它参数"); //2.阻塞主线程,使主线程等待执行完毕
string data2 = null;
var aysncResult2 = funcDelegate.BeginInvoke("这是来自主线程的参数2", null, null); data2 = funcDelegate.EndInvoke(aysncResult2);//第一种阻塞方法 while (!aysncResult2.IsCompleted) //第二种阻塞方法
{
Thread.Sleep(200); //虚拟操作
Console.WriteLine("主线程等待...");
}
data2 = funcDelegate.EndInvoke(aysncResult2); WaitHandle[] waitHandles = new WaitHandle[]{ aysncResult2.AsyncWaitHandle };
while (WaitHandle.WaitAll(waitHandles, 5000)) //第三种阻塞方法
{
Console.WriteLine("主线程等待...");
}

6. EAP(基于事件的异步编程)--主要用在客户端应用程序中

示例:

            //例子一
var client = new WebClient();
client.DownloadProgressChanged += delegate(object s, DownloadProgressChangedEventArgs e)
{
Console.WriteLine("Download Percent:{0}", e.ProgressPercentage);
};
client.DownloadStringCompleted += delegate(object s,DownloadStringCompletedEventArgs e){
Console.WriteLine("Download Content Length:{0}",e.Result.Length);
Console.WriteLine("Download Completed!");
}; client.DownloadStringAsync(new Uri("http://www.zuowenjun.cn")); //例子二
BackgroundWorker worker = new BackgroundWorker();
worker.DoWork += (s, e) => {
Console.WriteLine("异步执行中。。。");
};
worker.RunWorkerCompleted += (s, e) => {
Console.WriteLine("异步执行完成。。。");
};
worker.RunWorkerAsync();

7.async和await关键字

示例:

	public Task<double> GetValueAsync(double num1, double num2)
{
return Task.Run(() =>
{
for (int i = 0; i < 1000000; i++)
{
num1 = num1 / num2;
}
return num1;
});
}
public async void DisplayValue()
{
double result = await GetValueAsync(1234.5, 1.01);//此处会开新线程处理GetValueAsync任务,然后方法马上返回
//这之后的所有代码都会被封装成委托,在GetValueAsync任务完成时调用
System.Diagnostics.Debug.WriteLine("Value is : " + result);
} //调用
DisplayValue();//不会阻塞主线程

参考以下相关文章:

C#综合揭秘——细说多线程(上)

C#综合揭秘——细说多线程(下)

8天玩转并行开发系列文章

.NET基础拾遗(5)多线程开发基础

C#多线程技术总结(异步)的更多相关文章

  1. [Xcode 实际操作]八、网络与多线程-(22)使用GCD多线程技术异步下载图片

    目录:[Swift]Xcode实际操作 本文将演示如何使用使用GCD多线程技术异步下载图片. Grand Central Dispatch(GCD) 是 Apple 开发的一个多核编程的较新的解决方法 ...

  2. iOS多线程技术方案

    iOS多线程技术方案 目录 一.多线程简介 1.多线程的由来 2.耗时操作的模拟试验 3.进程和线程 4.多线程的概念及原理 5.多线程的优缺点和一个Tip 6.主线程 7.技术方案 二.Pthrea ...

  3. 多线程技术 NSThread & NSOperation & GCD

    多线程:在iOS开发中,用到多线程的处理问题的时候有很多,比如异步下载数据时刷新界面等等. 引入多线程来处理问题的关键就是,基于多线程可以使界面更加流畅,防止界面假死. 界面假死:比如你单击一个按钮来 ...

  4. iOS的三种多线程技术NSThread/NSOperation/GCD

    1.iOS的三种多线程技术 1.NSThread 每个NSThread对象对应一个线程,量级较轻(真正的多线程) 2.以下两点是苹果专门开发的"并发"技术,使得程序员可以不再去关心 ...

  5. 多线程技术在iOS开发中的使用

    进程和线程 要使用多线程,首先需要理解进程和线程这2个概念.这里我简单的说一下. 所谓进程对应的是一个应用程序,负责开辟内存空间供应用程序使用,但是进程不能执行任务(指令).一个进程至少包含一条线程, ...

  6. OS X 和iOS 中的多线程技术(下)

    OS X 和iOS 中的多线程技术(下) 上篇文章中介绍了 pthread 和 NSThread 两种多线程的方式,本文将继续介绍 GCD 和 NSOperation 这两种方式.. 1.GCD 1. ...

  7. iOS- NSThread/NSOperation/GCD 三种多线程技术的对比及实现

    1.iOS的三种多线程技术 1.NSThread 每个NSThread对象对应一个线程,量级较轻(真正的多线程) 2.以下两点是苹果专门开发的“并发”技术,使得程序员可以不再去关心线程的具体使用问题 ...

  8. iOS- NSThread/NSOperation/GCD 三种多线程技术的对比及实现 -- 转

    1.iOS的三种多线程技术 1.NSThread 每个NSThread对象对应一个线程,量级较轻(真正的多线程) 2.以下两点是苹果专门开发的“并发”技术,使得程序员可以不再去关心线程的具体使用问题 ...

  9. NSThread/NSOperation/GCD 三种多线程技术

    1.iOS的三种多线程技术 1.NSThread 每个NSThread对象对应一个线程,量级较轻(真正的多线程) 2.以下两点是苹果专门开发的“并发”技术,使得程序员可以不再去关心线程的具体使用问题 ...

随机推荐

  1. VS2008 Pocket PC 2003 SE仿真程序上网设置

    设置大体分为3个步骤:Microsoft ActiveSync安装配置.Pocket PC 2003 SE仿真程序配置.Pocket PC 2003连接到Microsoft ActiveSync. 1 ...

  2. [.NET领域驱动设计实战系列]专题三:前期准备之规约模式(Specification Pattern)

    一.前言 在专题二中已经应用DDD和SOA的思想简单构建了一个网上书店的网站,接下来的专题中将会对该网站补充更多的DDD的内容.本专题作为一个准备专题,因为在后面一个专题中将会网上书店中的仓储实现引入 ...

  3. 【C语言学习】《C Primer Plus》第5章 运算符、表达式和语句

    学习总结 1.有了一定的语言基础,运算符和表达式这些都大同小异,无外乎赋值运算符(=).算术运算符(+.-.*./.%.++.——)和其他的一下运算符(sizeof.(type)). 2.声明一个参数 ...

  4. 用WPF实现查找结果高亮显示

    概述 我们经常会遇到这样的需求:到数据库里查找一些关键字,把带这些关键字的记录返回显示在客户端上.但如果仅仅是单纯地把文本显示出来,那很不直观,用户不能很轻易地看到他们想找的内容,所以通常我们还要做到 ...

  5. [翻译].NET随机数

    原文链接:http://csharpindepth.com/Articles/Chapter12/Random.aspx   随机数 当你在Stack Overflow上看到看到某个问题标题当中有“随 ...

  6. WaterfallTree(瀑布树) 详细技术分析系列

    前言 WaterfallTree(瀑布树) 是最强纯C#开源NoSQL和虚拟文件系统-STSdb专有的(版权所有/专利)算法/存储结构. 参考 关于STSdb,我之前写过几篇文章,譬如: STSdb, ...

  7. Qt5.3编译错误——call of overloaded ‘max(int int)’is ambiguous

    错误描述: 今天在使用Qt写一个C++函数模板的测试程序的时候,编译的时候,编译的时候出现如下错误: 错误描述为:在main函数中,进行函数max()重载时,出现(ambiguous)含糊的,不明确的 ...

  8. jQuery插件开发的五种形态[转]

    这篇文章主要介绍了jQuery插件开发的五种形态小结,具体的内容就是解决javascript插件的8种特征,非常的详细. 关于jQuery插件的开发自己也做了少许研究,自己也写过多个插件,在自己的团队 ...

  9. Node.js入门:模块机制

    CommonJS规范      早在Netscape诞生不久后,JavaScript就一直在探索本地编程的路,Rhino是其代表产物.无奈那时服务端JavaScript走的路均是参考众多服务器端语言来 ...

  10. atitit。企业的价值观 员工第一 vs 客户第一.docx

    atitit.企业的价值观 员工第一 vs 客户第一.docx 1. 客户第一的说法是错误的,员工优先是正确的,理念与价值观1 1.1. 任何一个组织,应该组织成员优先级要比外部成员高才对1 1.2. ...