多线程要点--CLR C#学习笔记
1、windows永远不会调度一个进程,只调度线程。
2、线程和操作系统的关系:CLR(X)--AppDomain--线程池(包含工作者线程和I/O线程)
3、线程的关键组成部分
A、线程执行上下文
占用的空间:
o x86->700字节内存
x64->1240字节内存
o IA64->2500字节内存
B、线程环境块(用户模式下应用程序能快速访问的地址空间),占用空间为1个内存页,在x86和x64系统中卫4KB,在IA64系统下为8KB。
C、用户模式栈,占用1MB内存空间。
D、内核模式栈,32位系统为12KB,64位系统为24KB内存。
4、windows桌面型系统的上下文切换时间为30毫秒左右(以windows7为例的理论时间)。
5、尽量减少线程数量的理由:
- 上线文切换的30毫秒时间开销
- 执行垃圾回收时,CLR会暂停、遍历所有线程。
- 线程越多,调试、跟踪程序的工作就会变的越困难。
- CPU对多线程的数量支持是有限的。
6、线程的优先级=进程优先级+线程优先级
优先级从低到高的顺序为:Idle,BelowNormal,Normal,Abore Normal,High,Realtime
7、特别提示:windows桌面和server操作系统不是实时的操作系统,不能保证线程的实时性。
8、针对线程执行上下文的编程:
- 阻止上下文流可以提高城乡的性能,尤其针对运行于服务器上应用程序。
o CallContext.LogicalSetData("Name","xx");
o ExecutionContext.SuppressFlow();//阻止上下文流动
o ExecutionContext.RestoreFlow();//恢复上下文流动
9、和线程相关的委托和回掉函数:
WaitCallback委托--------------------ThreadPool.QueueUserWorkItem()
TimerCallback委托-------------------System.Threading.Timer
ParameterizedThreadStart委托------System.Threading.Thread
回调分类:
A、普通不可取消回调
B、可取消的回调:
CancellationTokenSource CTS= new...
ThreadPool.QueueUserWorkItem(0=>Count(CTS.Token,1000));
Void Count(CancellationToken token,Int32 CountTo)
{
for....
If(token.IsCancellationRquested)
{
...
}
}
关联取消标记:
CancellationTokenSource.CreateLinedTokenSource(CTS1.Token,CTS2.Token);
10、使用专用线程的理由(System.Threading.Thread):一个需要长时间运行的任务。
11、ThreadPool的缺点:
- 无法跟踪操作的状态(回调函数内容);
- 无法获取操作的返回值(回调函数结果);
采用任务Task可以解决这两个问题
12、Parallel循环,并行循环静态方法,Parallel.For/ForEach
- 任何一次都会使整个循环集合终止,但是由于循环集合时分块并行执行,所以不会立刻得到终止。
- 不要为执行很快的操作使用Parallel循环。
13、Parallel.Invoke(()=>StaticFounction1(),()=>StaticFounction2);
多线程要点--CLR C#学习笔记的更多相关文章
- 《Java多线程编程核心技术》学习笔记
第2章 对象及变量的并发访问 2.1 synchronized同步方法 方法内的变量为线程安全: 方法内部的变量是线程私有的 方法中有一个变量num,后面对它赋值 两个线程同时调用这个方法,对其赋不同 ...
- android 多线程 异步消息处理 服务 学习笔记 (六)
三种多线程编程方法 1 class Mythread extends Thread{ @Override public void run(){} } new Mythread().start() 2 ...
- java 多线程——并发编程模型 学习笔记
并发编程模型 ...
- Java多线程技术学习笔记(一)
目录: 概述 多线程的好处与弊端 JVM中的多线程解析 多线程的创建方式之一:继承Thread类 线程的状态 多线程创建的方式之二:实现Runnable接口 使用方式二创建多线程的好处 多线程示例 线 ...
- 0037 Java学习笔记-多线程-同步代码块、同步方法、同步锁
什么是同步 在上一篇0036 Java学习笔记-多线程-创建线程的三种方式示例代码中,实现Runnable创建多条线程,输出中的结果中会有错误,比如一张票卖了两次,有的票没卖的情况,因为线程对象被多条 ...
- 转:学习笔记:delphi多线程学识
学习笔记:delphi多线程知识 最近一直在温习旧的知识,刚好学习了一下Java的线程安全方面的知识,今天想起之前一直做的Delphi开发,所以还是有必要温习一下,看看这些不同的编程语言有什么不同之处 ...
- Java学习笔记-多线程-创建线程的方式
创建线程 创建线程的方式: 继承java.lang.Thread 实现java.lang.Runnable接口 所有的线程对象都是Thead及其子类的实例 每个线程完成一定的任务,其实就是一段顺序执行 ...
- 孙鑫VC学习笔记:多线程编程
孙鑫VC学习笔记:多线程编程 SkySeraph Dec 11st 2010 HQU Email:zgzhaobo@gmail.com QQ:452728574 Latest Modified ...
- Java多线程技术学习笔记(二)
目录: 线程间的通信示例 等待唤醒机制 等待唤醒机制的优化 线程间通信经典问题:多生产者多消费者问题 多生产多消费问题的解决 JDK1.5之后的新加锁方式 多生产多消费问题的新解决办法 sleep和w ...
随机推荐
- Array操作方法和String操作方法比较
Array 的操作方法和 String 的操作方法老是弄混>_<,下面就对于这两个对象的常用操作方法进行比较~~ Array ☞ 操作方法 concat():returns a new a ...
- css中的width,height,属性与盒模型的关系
这段话很容易记住盒模型: css中盒子模型包含属性margin.border.padding.content,他们可以把它转移到我们日常生活中的盒子(箱 子)上来理解,日常生活中所见的盒子也具有这些属 ...
- 三分钟了解Activity工作流
一. 什么是工作流 以请假为例,现在大多数公司的请假流程是这样的 员工打电话(或网聊)向上级提出请假申请——上级口头同意——上级将请假记录下来——月底将请假记录上交公司——公司将请假录入电脑 采用工作 ...
- Scrum第一天任务认领情况
在团队项目“广商百货”的SCRUM项目中我认领的任务是对登录注册界面进行完善.具体功能还没有实现,还在学习中...
- makefile--目标搜索(八)
原创博文,转载请标明出处--周学伟http://www.cnblogs.com/zxouxuewei/ 在一个较大的工程中,一般会将源代码和二进制文件(.o 文件和可执行文件)安排在不同的目录来进行区 ...
- poj2492 带权并查集
题意:研究一种生物,有n个生物个体,发现有一些之间进行了交配,给出了这些关系,问是否有同性恋的bug出现. 用0\1表示某元素和其祖先元素的性别关系,0 为相同,1 为不同,用 mod2 实现累计处理 ...
- click 绑定(三)防止事件冒泡
防止事件冒泡 默认情况下,Knockout允许click事件继续在更高一层的事件句柄上冒泡执行.例如,如果你的元素和父元素都绑定了click事件,那当你点击该元素的时候两个事件都会触发的.如果需要, ...
- 【BZOJ1005】【HNOI2008】明明的烦恼
又是看黄学长的代码写的,估计我的整个BZOJ平推计划都要看黄学长的代码写 原题: 自从明明学了树的结构,就对奇怪的树产生了兴趣......给出标号为1到N的点,以及某些点最终的度数,允许在任意两点间连 ...
- UMDH
1. 什么是UMDH UMDH=User Mode dump heap.把进程的堆dump下来.包括堆栈信息.UMDH是WinDbg附带的一个工具. 2. 下载安装 WinDbg.完事后在WinDbg ...
- vim配置及插件安装管理(超级详细)[转]
1 写在前面 Linux下编程一直被诟病的一点是: 没有一个好用的IDE, 但是听说Linux牛人, 黑客之类的也都不用IDE. 但是对我等从Windows平台转移过来的Coder来说, 一个好用 ...