Master-Worker模式是常用的并行模式之一,它的核心思想是,系统有两个进程协作工作:Master进程,负责接收和分配任务;Worker进程,负责处理子任务。当Worker进程将子任务处理完成后,结果返回给Master进程,由Master进程做归纳汇总,最后得到最终的结果。 一、什么是Mast ...
分类:
其他好文 时间:
2017-11-02 01:01:38
阅读次数:
185
1,线程饥饿死锁 在线程池中,如果任务依赖于其他任务,那么可能产生死锁。在单线程的Executor中,如果一个任务将另一个任务提交到同一个Executor,并且等待这个被提交任务的结果,那么通常会引发死锁。第二个任务停留在工作队列中,等待第一个任务完成,而第一个任务又无法完成,因为它在等待第二个任务 ...
分类:
编程语言 时间:
2017-09-07 00:50:07
阅读次数:
257
本文转自如何使用queue_delayed_work函数 1. delayed_workqueue主要用在需要延迟处理任务的驱动中,这些驱动的特性主要是不能使用中断。 delayed_workqueue的使用步骤如下: 1) 定义workqueue要做的delayed工作:struct delaye ...
分类:
其他好文 时间:
2017-08-20 18:31:18
阅读次数:
3492
构造函数中需要传入的参数包括corePoolSize、maximumPoolSize、keepAliveTime、timeUnit和workQueue。要明确理解这些参数(和后续将要介绍的参数)的含义,就首先要搞清楚ThreadPoolExecutor线程池的逻辑结构。 一定要注意一个概念,即存在于 ...
分类:
其他好文 时间:
2017-07-18 23:18:24
阅读次数:
322
RabbitMQ学习(三)订阅/发布 1.RabbitMQ模型 前面所学都只用到了生产者、队列、消费者。如上图所示,其实生产者并不直接将信息传输到队列中,在生产者和队列中间有一个交换机(Exchange),我们之前没有使用到交换机是应为我们没有配置交换机,使用了默认的交换机。 有几个可供选择的交换机 ...
分类:
其他好文 时间:
2017-07-13 16:15:53
阅读次数:
162
具体流程如下: 1)当池子大小小于corePoolSize就新建线程,并处理请求 2)当池子大小等于corePoolSize,把请求放入workQueue中,池子里的空闲线程就去从workQueue中取任务并处理 3)当workQueue放不下新入的任务时,新建线程入池,并处理请求,如果池子大小撑到 ...
分类:
其他好文 时间:
2017-06-18 18:12:37
阅读次数:
105
1. ThreadPoolExecutor逻辑结构和工作方式 我们创建线程池的时候使用了ThreadPoolExecutor中最简单的一个构造函数: 构造函数中需要传入的参数包括corePoolSize、maximumPoolSize、keepAliveTime、timeUnit和workQueue ...
分类:
编程语言 时间:
2017-06-07 18:53:11
阅读次数:
172
在没有看不论什么代码之前首先想一下线程池应该有哪几部分: 任务队列线程 任务队列非常好办,直接用堵塞队列就能够了:BlockingQueue<Runnable> workQueue。而线程是用来运行任务的,那么理所当然应该是不断地从任务队列中取出任务来运行,我们来看ThreadPoolExecuto ...
分类:
编程语言 时间:
2017-06-05 16:41:33
阅读次数:
180
在没有看不论什么代码之前首先想一下线程池应该有哪几部分: 任务队列线程 任务队列非常好办。直接用堵塞队列就能够了:BlockingQueue<Runnable> workQueue。而线程是用来运行任务的,那么理所当然应该是不断地从任务队列中取出任务来运行,我们来看ThreadPoolExecuto ...
分类:
编程语言 时间:
2017-05-25 23:29:55
阅读次数:
220
在ThreadPool 类中定义了一个LinkedList 类型的 workQueue 成员变量, 它表示工作队列, 用来存放线程池要执行的任务, 每个任务都是 Runnable 实例. Thread...
分类:
其他好文 时间:
2017-04-27 16:17:41
阅读次数:
244