选择特殊符号
选择搜索类型
请输入搜索
在面向对象编程中,创建和销毁对象是很费时间的,因为创建一个对象要获取内存资源或者其它更多资源。在Java中更是如此,虚拟机将试图跟踪每一个对象,以便能够在对象销毁后进行垃圾回收。所以提高服务程序效率的一个手段就是尽可能减少创建和销毁对象的次数,特别是一些很耗资源的对象创建和销毁。如何利用已有对象来服务就是一个需要解决的关键问题,其实这就是一些"池化资源"技术产生的原因。比如大家所熟悉的数据库连接池正是遵循这一思想而产生的,本文将介绍的线程池技术同样符合这一思想。
目前,一些著名的大公司都特别看好这项技术,并早已经在他们的产品中应用该技术。比如IBM的WebSphere,IONA的Orbix 2000在SUN的 Jini中,Microsoft的MTS(Microsoft Transaction Server 2.0),COM 等。
服务器程序利用线程技术响应客户请求已经司空见惯,可能您认为这样做效率已经很高,但您有没有想过优化一下使用线程的方法。该文章将向您介绍服务器程序如何利用线程池来优化性能并提供一个简单的线程池实现。
1、线程池管理器(ThreadPoolManager):用于创建并管理线程池
2、工作线程(WorkThread): 线程池中线程
3、任务接口(Task):每个任务必须实现的接口,以供工作线程调度任务的执行。
4、任务队列:用于存放没有处理的任务。提供一种缓冲机制。
线程池(英语:thread pool):一种线程使用模式。线程过多会带来调度开销,进而影响缓存局部性和整体性能。而线程池维护着多个线程,等待着监督管理者分配可并发执行的任务。这避免了在处理短时间任务时创建与销毁线程的代价。线程池不仅能够保证内核的充分利用,还能防止过分调度。可用线程数量应该取决于可用的并发处理器、处理器内核、内存、网络sockets等的数量。 例如,线程数一般取cpu数量 2比较合适,线程数过多会导致额外的线程切换开销。
任务调度以执行线程的常见方法是使用同步队列,称作任务队列。池中的线程等待队列中的任务,并把执行完的任务放入完成队列中。
线程池模式一般分为两种:HS/HA半同步/半异步模式、L/F领导者与跟随者模式。
半同步/半异步模式又称为生产者消费者模式,是比较常见的实现方式,比较简单。分为同步层、队列层、异步层三层。同步层的主线程处理工作任务并存入工作队列,工作线程从工作队列取出任务进行处理,如果工作队列为空,则取不到任务的工作线程进入挂起状态。由于线程间有数据通信,因此不适于大数据量交换的场合。
领导者跟随者模式,在线程池中的线程可处在3种状态之一:领导者leader、追随者follower或工作者processor。任何时刻线程池只有一个领导者线程。事件到达时,领导者线程负责消息分离,并从处于追随者线程中选出一个来当继任领导者,然后将自身设置为工作者状态去处置该事件。处理完毕后工作者线程将自身的状态置为追随者。这一模式实现复杂,但避免了线程间交换任务数据,提高了CPU cache相似性。在ACE(Adaptive Communication Environment)中,提供了领导者跟随者模式实现。
线程池的伸缩性对性能有较大的影响。
创建太多线程,将会浪费一定的资源,有些线程未被充分使用。
销毁太多线程,将导致之后浪费时间再次创建它们。
创建线程太慢,将会导致长时间的等待,性能变差。
销毁线程太慢,导致其它线程资源饥饿。
保水剂是对农用高吸水性树脂(Super Absorbent Ploymer ,简称SAP)的统称。1969年美国农业部北方研究中心首先研制出保水剂,20世纪70年代中期将其用于玉米、大豆涂层、树苗移栽...
回答:软件在汇总计算的时候将多线程计算打钩即可提高绘图速度
这个应该计算速度比较快的!可能你的电脑配置问题导致慢的吧!
应用程序可以有多个线程,这些线程在休眠状态中需要耗费大量时间来等待事件发生。其他线程可能进入睡眠状态,并且仅定期被唤醒以轮循更改或更新状态信息,然后再次进入休眠状态。为了简化对这些线程的管理,.NET框架为每个进程提供了一个线程池,一个线程池有若干个等待操作状态,当一个等待操作完成时,线程池中的辅助线程会执行回调函数。线程池中的线程由系统管理,程序员不需要费力于线程管理,可以集中精力处理应用程序任务。
调用QueueUserWorkItem时传入的Object类型参数传递到任务过程,可以通过这种方式来向任务过程传递参数。如果任务过程需要多个参数,可以定义包含这些数据的类,并将其强制转换为Object数据类型。
1、需要大量的线程来完成任务,且完成任务的时间比较短。 WEB服务器完成网页请求这样的任务,使用线程池技术是非常合适的。因为单个任务小,而任务数量巨大,你可以想象一个热门网站的点击次数。 但对于长时间的任务,比如一个Telnet连接请求,线程池的优点就不明显了。因为Telnet会话时间比线程的创建时间大多了。
2、对性能要求苛刻的应用,比如要求服务器迅速响应客户请求。
3、接受突发性的大量请求,但不至于使服务器因此产生大量线程的应用。突发性大量客户请求,在没有线程池情况下,将产生大量线程,虽然理论上大部分操作系统线程数目最大值不是问题,短时间内产生大量线程可能使内存到达极限,并出现"OutOfMemory"的错误。
//线程池示例 usingSystem; usingSystem.Threading;publicclassTest { //存放要计算的数值的字段 staticdoublenumber1=-1; staticdoublenumber2=-1;publicstaticvoidMain() { //获取线程池的最大线程数和维护的最小空闲线程数 intmaxThreadNum,minThreadNum; intportThreadNum; ThreadPool.GetMaxThreads(outmaxThreadNum,outportThreadNum); ThreadPool.GetMinThreads(outminThreadNum,outportThreadNum); Console.WriteLine("最大线程数:{0}",maxThreadNum); Console.WriteLine("最小线程数:{0}",minThreadNum); //函数变量值 intx=15600; //启动第一个任务:计算x的8次方 Console.WriteLine("启动第一个任务:计算{0}的8次方。",x); ThreadPool.QueueUserWorkItem(newWaitCallback(TaskProc1),x); //启动第二个任务:计算x的8次方根 Console.WriteLine("启动第二个任务:计算{0}的8次方根。",x); ThreadPool.QueueUserWorkItem(newWaitCallback(TaskProc2),x); //等待,直到两个数值都完成计算 while(number1==-1||number2==-1); //打印计算结果 Console.WriteLine("y({0})={1}",x,number1 number2); Console.Read(); } //启动第一个任务:计算x的8次方 staticvoidTaskProc1(objecto) { number1=Math.Pow(Convert.ToDouble(o),8); } //启动第二个任务:计算x的8次方根 staticvoidTaskProc2(objecto) { number2=Math.Pow(Convert.ToDouble(o),1.0/8.0); } }
[HostProtection(SecurityAction.LinkDemand,Synchronization=true,ExternalThreading=true)]publicstaticclassThreadPool { [Obsolete("ThreadPool.BindHandle(IntPtr)hasbeendeprecated.PleaseuseThreadPool.BindHandle(SafeHandle)instead.",false),SecurityPermission(SecurityAction.Demand,Flags=SecurityPermissionFlag.UnmanagedCode)] publicstaticboolBindHandle(IntPtrosHandle) { if(osHandle==null){thrownewArgumentNullException("osHandle");} boolflag=false; boolsuccess=false; RuntimeHelpers.PrepareConstrainedRegions(); try { osHandle.DangerousAddRef(refsuccess); flag=BindIOCompletionCallbackNative(osHandle.DangerousGetHandle()); } finally { if(success) osHandle.DangerousRelease(); } returnflag; }
船板钢的技术背景
目前,宽厚板生产的主要品种有碳素结构钢板、 优质碳素结构钢板、 低合金高强度结构钢板、 造船用钢板、管线用钢板、工程机械用钢板、汽车大梁板、桥梁板等,船板钢是宽厚板的主 要专用板品种之一。 中国是造船业大国, 对船板钢的需求越来越大,同时船舶的大型化、高 速化以及海洋油气田的开发, 为高强度船体结构钢的应用提供了广阔的应用前景, 所以有必 要对船板钢的发展趋势、生产技术特别是高强船板钢的生产控制技术进行研究。 造船用宽厚钢板钢种包括一般强度船板 (A~E),高强度船板 (AH32-EH40),超高强度船板钢 (AH42-FH69),船用锅炉板,造船及海洋平台用 z 向钢板等。船板钢生产主要技术由高碳单 元素、低碳多元素、 向微合金化和复合微合金化方向发展;由低强度级别向高强度级别、超 高强度级别发展,目前,船板钢的强度一般可达 450~980MPa。 最初的船板钢使用铁素体加珠光体的碳锰低
1建设背景
1.建设背景 为全面贯彻中共中央《建立健全惩治和预防腐败体系 2000-2012 年工作规 划》、国务院《关于加强市县政府依法行政的决定》和《国务院办公厅转发监察 部等部门关于深入推进行政审批制度改革意见的通知》 (国办发 [2008]115 号) 精神要求,根据市委市政府关于《关于开展行政权力公开高效运行工作的意见》 (合发 [2008]25 号)精神,进一步深化行政审批制度改革,不断提高行政审批 工作效能,加大行政执法工作的透明性、公正性,促进服务型政府、透明政府、 廉洁型政府、绩效型政府的建设,结合合肥市的实际,特制定本需求方案。 2.电子政务现状 合肥市具备政务外网建设, 行政服务中心原有系统使用合肥市政务外网, 政 务外网的铺设已经到达各区和街道, 是党政机关公共业务网络, 与互联网逻辑隔 离,主要满足各级政府部门进行社会管理、 公共服务等面向社会服务的需要, 通 过将各局纳入政
守护线程是特殊的线程,一般用于在后台为其他线程提供服务.
Java中,isDaemon():判断一个线程是否为守护线程.
Java中,setDaemon():设置一个线程为守护线程.
C# 守护线程
类1:守护线程类
/** * 本线程设置了一个超时时间 * 该线程开始运行后,经过指定超时时间, * 该线程会抛出一个未检查异常通知调用该线程的程序超时 * 在超时结束前可以调用该类的cancel方法取消计时 * @author solonote */public class TimeoutThread extends Thread{ /** * 计时器超时时间 */ private long timeout; /** * 计时是否被取消 */ private boolean isCanceled = false; /** * 当计时器超时时抛出的异常 */ private TimeoutException timeoutException; /** * 构造器 * @param timeout 指定超时的时间 */ public TimeoutThread(long timeout,TimeoutException timeoutErr) { super(); this.timeout = timeout; this.timeoutException = timeoutErr; //设置本线程为守护线程 this.setDaemon(true); } /** * 取消计时 */ public synchronized void cancel() { isCanceled = true; } /** * 启动超时计时器 */ public void run() { try { Thread.sleep(timeout); if(!isCanceled) throw timeoutException; } catch (InterruptedException e) { e.printStackTrace(); } } }
(1)创建线程
当创建一个新的进程时,也创建一个新的线程,进程中的线程可以在同一进程中创建新的线程。
(2)终止线程
可以正常终止自己,也可能某个线程执行错误,由其它线程强行终止。终止线程操作主要负责释放线程占有的寄存器和栈
(3)阻塞线程
当线程等待每个事件无法运行时,停止其运行。
(4)唤醒线程
当阻塞线程的事件发生时,将被阻塞的线程状态置为就绪态,将其挂到就绪队列。进程仍然具有与执行相关的状态。例如,所谓进程处于“执行”状态,实际上是指该进程中的某线程正在执行。对进程施加的与进程状态有关的操作,也对其线程起作用。例如,把某个进程挂起时,该进程中的所有线程也都被挂起,激活也是同样。
在多线程OS中,通常是在一个进程中包括多个线程,每个线程都是作为利用CPU的基本单位,是花费最小开销的实体。线程具有以下属性。
1)轻型实体
线程中的实体基本上不拥有系统资源,只是有一点必不可少的、能保证独立运行的资源。
线程的实体包括程序、数据和TCB。线程是动态概念,它的动态特性由线程控制块TCB(Thread Control Block)描述。TCB包括以下信息:
(1)线程状态。
(2)当线程不运行时,被保存的现场资源。
(3)一组执行堆栈。
(4)存放每个线程的局部变量主存区。
(5)访问同一个进程中的主存和其它资源。
用于指示被执行指令序列的程序计数器、保留局部变量、少数状态参数和返回地址等的一组寄存器和堆栈。
2)独立调度和分派的基本单位。
在多线程OS中,线程是能独立运行的基本单位,因而也是独立调度和分派的基本单位。由于线程很“轻”,故线程的切换非常迅速且开销小(在同一进程中的)。
3)可并发执行。
在一个进程中的多个线程之间,可以并发执行,甚至允许在一个进程中所有线程都能并发执行;同样,不同进程中的线程也能并发执行,充分利用和发挥了处理机与外围设备并行工作的能力。
4)共享进程资源。
在同一进程中的各个线程,都可以共享该进程所拥有的资源,这首先表现在:所有线程都具有相同的地址空间(进程的地址空间),这意味着,线程可以访问该地址空间的每一个虚地址;此外,还可以访问进程所拥有的已打开文件、定时器、信号量机构等。由于同一个进程内的线程共享内存和文件,所以线程之间互相通信不必调用内核。