1.线程正常执行,正常结束。
2.监控某些条件并结束线程的不间断运行。
3.捕获interruptedexc
在d:。
线程。结束的
线程。等待
也就是先触发t:真
否则,an"无效句柄"当waitfor即将结束时将导致错误。当窗体关闭时,该方法将等待一个事件(因为等待)。
因此,如果我们不t在主窗体中结束线程,我们不不一定要使用waitfor。相反,:使用下面的方法在关闭表单的代码中直接调用fr:tru:。如果线程。在终止:somefunction设置时,尝试设置线程。在调用pcmthrd之前终止:nil。终止,以避免线程结束后某些函数中的变量出现空指针错误。当然,这不是绝对的,需要根据具体程序来确定。
一、threadpoolexecutor的重要参数
corepoolsize:核心线程的数量。核心线程会一直存活,没有任务要及时执行。当线程数小于核心线程数时,即使有空闲线程,线程池也会优先创建新线程进行处理。当allowcorethreadtimeouttrue(默认为false)被设置时,核心线程将随着时间的推移而关闭。
queuecapacity:任务队列容量(阻塞队列)
当核心线程的数量达到最大值时,新任务将排队等待执行。
maxpoolsize:最大线程数
当线程数为gtcorepoolsize且任务队列已满时。线程池创建新的线程来处理任务。
当线程数为maxpoolsize且任务队列已满时,线程池将拒绝处理任务并抛出异常。keepalivetime:线程空闲时间
当线程的空闲时间达到keepalivetime时,线程将退出,直到线程数达到corepoolsize。
如果allowcorethreadtimeouttrue,它将一直等到线程数为0。
allowcorethreadtimeout:允许核心线程超时。
rejectedexecutionhandler:任务拒绝处理程序
拒绝处理任务有两种情况:
当线程数量达到maxpoolsize且队列已满时,新任务将被拒绝。
当线程池被调用shutdown()时,它将在关闭之前等待线程池中的任务完成。如果在调用shutdown()和线程池实际关闭之间提交了一个任务,新任务将被拒绝。
线程池将调用rejectedexecutionhandler来处理这个任务。如果默认值为abortpolicy,将引发异常。
threadpoolexecutor类有几个内部实现类来处理这种情况:
abortpolicy丢弃任务并引发运行时异常。
callerrunspolicy执行任务
discardpolicy忽略它,什么也不会发生。
discardoldestpolicy将首先进入队列(最后执行)的任务从队列中踢出。
实现rejectedexecutionhandler接口,可以自定义处理器。
二、threadpoolexecutor的执行顺序
线程池执行如下任务
(1)当线程数小于核心线程数时,创建线程。
(2)当线程数大于等于核心线程数且任务队列未满时,将任务放入任务队列。
(3)当线程数大于或等于核心线程数且任务队列已满时。
1)如果线程数小于最大线程数,则创建线程。
2)如果线程数等于最大线程数,抛出异常,拒绝任务。
第三,如何设置参数
系统默认值
核心池大小1
_值
_值
keepalivetime60s
allowcorethreadtimeoutfalse
rejectedexecutionhandlerabortpolicy()
如何设置它
需要根据几个值来决定。
任务:每秒的任务数,假设为500~1000。
taskcost:每个任务都需要时间,假设0.1s
responsetime:系统允许的最大响应时间,假设为1s。
做一些计算
corepoolsize每秒需要处理多少线程?
线程计数tasks/(1/taskcost)任务*taskcout(500~1000)*0.150~100线程。corepoolsize设置应大于50。
根据8020原理,如果每秒80%的任务小于800,那么corepoolsize可以设置为80。
queuecapacity(核心大小池/任务成本)*响应时间
计算可用队列容量80/0.1*180。意味着队列中的线程可以等待1s,超过1s就需要新的线程来执行。
记住它可以t设置为_value,这样队列会非常大,线程数量只会保持在corepoolsize大小。当任务急剧增加时,没有新的线程可以打开执行,响应时间会急剧增加。
maxpoolsize(最大任务数)-队列容量)/(1/任务成本)
可以得到计算的maxpoolsize(1000-80)/1092。
(最大任务数-队列容量)/每个线程每秒处理能力的最大线程数
rejectedexecutionhandler:根据具体情况,任务不重要可以丢弃,而重要的任务要通过一些缓冲机制来处理。
默认情况下,通常满足keepalivetime和allowcorethreadtimeout。
以上都是理想值,要根据机器的性能来决定。如果在未达到最大线程数的情况下,机器的cpu负载已满,则需要通过升级硬件、优化代码、降低taskcost来处理。