Skip to content

dewafer/dumb-threading

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

4 Commits
 
 
 
 
 
 
 
 

Repository files navigation

多线程演示项目

本项目包含了3个程序,分别演示了:

  • com.dewafer.threading.demo.RootReduceProcessor: 任务列表线程递归切块分配处理(仿Java8 Spliterator + fork/join framework实现的parallelStream API)
  • com.dewafer.threading.demo.SingleProducerMultiConsumerDemo: 生产-消费模式,单线程生产者,多线程处理者
  • com.dewafer.threading.demo.SingleProducerSingleConsumerDemo: 生产-消费模式,单线程生产者,单线程处理者。

本项目仅依赖Java 6,主要靠java.util.concurrent.*包下的类,譬如BlockingQueue,ExecutorService,Callable,Future等类实现。

使用方法

pom.xml中加入:

<repositories>
    <repository>
        <id>dumb-threading-mvn-repo</id>
        <url>https://raw.githubusercontent.com/dewafer/dumb-threading/mvn-repo/</url>
        <snapshots>
            <enabled>true</enabled>
            <updatePolicy>always</updatePolicy>
        </snapshots>
    </repository>
</repositories>

<dependencies>
    <dependency>
        <groupId>com.dewafer</groupId>
        <artifactId>dumb-threading</artifactId>
        <version>1.0-SNAPSHOT</version>
    </dependency>
</dependencies>

主要类说明

com.dewafer.threading.demo.main.ProducerConsumerMain

程序主入口之一。将会首先运行3次单线程生产者、单线程消费者演示,然后再运行3次单线程生产者、多线程消费者演示。

com.dewafer.threading.demo.main.ReduceProcessorMain

程序主入口之一。将会运行3次任务列表切块并行处理演示。

com.dewafer.threading.demo.support.Producer

生产者接口,生产者的实现必须实现此接口的以下两个方法:

  • T produce(): 产生被消费者消费的类的对象。
  • boolean hasNext(): 返回boolean表示该生产者是否还能继续生产。

com.dewafer.threading.demo.support.Consumer

消费者接口,消费者的实现类必须实现此接口的以下两个方法:

  • boolean accept(T t): 消费者消费的对象首先会传入此方法,返回boolean值表示消费者是否愿意消费此对象,如果返回false则该消费者的consume方法将不会运行。
  • R consume(T t): 消费者具体消费方法的实现接口。仅当accept方法返回true此方法才会执行。返回消费后产物。

com.dewafer.threading.demo.support.Consumer

消费者工厂接口,用来生产消费者实现的对象。

com.dewafer.threading.demo.support.Reducer

消减器接口。与Consumer相同,区别仅在Reducer没有accept方法,返回null表示该对象不能被消费。

com.dewafer.threading.demo.impl.StringProducer

实现了Producer接口的字符串生产者,随机产生长度为3到7个字符的纯英文小写字母字符串,生产的个数由MAX字段指定。

com.dewafer.threading.demo.impl.ReverseConsumer

实现了Consumer接口的字符串消费者,只接受回文。如aaa,aba,abcba等。消费时(仅consume方法中),会随机等待0.2-1.2秒。消费的产物为回文原文。

com.dewafer.threading.demo.impl.ReverseConsumerFactory

实现了ConsumerFactory接口的字符串生产者工厂,将会产生ReverseConsumer对象。

com.dewafer.threading.demo.impl.StringReducerImpl

ReverseConsumer相同,区别仅在于,当消费对象不是回文时将返回null(不接受时不等待,消费时则会等待)。

com.dewafer.threading.demo.SingleProducerSingleConsumerDemo

单线程生产者、单线程消费者演示类。

该类会首先在当前线程(主线程)上启动一个消费者线程(由向ExecutorService提交BlockingQueuedConsumerRunnerWrapper实现), 然后由主线程担当生产者角色,使用由构造器提供的Producer产生产品放入阻塞列队。 当生产者生产完成时,向列队中加入生产终止信号(END_OF_QUEUE), 然后等待消费者线程完成并返回消费者消费的结果。

不考虑列队或消费者线程被迫中断的情况,如发生中断或执行列外,将会返回空结果集。

com.dewafer.threading.demo.SingleProducerMultiConsumerDemo

单线程生产者、多线程消费者演示。

过程与SingleProducerSingleConsumerDemo类似,不同之处在于本演示不使用阻塞列队, 而是针对每一个生产者产生的对象,提请启用新线程处理(由向ExecutorService提交NoneBlockingConsumerRunnerWrapper实现), 并收集每个提请的将来结果(Future对象),在生产者生产完成后等待并归集每个提请的结果。

对中断处理的方针与SingleProducerSingleConsumerDemo相同,但是如在归集将来结果时发生中断或执行例外,将会返回当前已经收集到的结果集而不是空结果集。

com.dewafer.threading.demo.BlockingQueuedConsumerRunnerWrapper

在单线程生产者消费者演示中负责任务列表的调度以及消费者线程的运行。实现了Callable接口。 会从任务列队中取任务然后让消费者进行处理,当任务列队接饥饿时将阻塞。当遇到终止信号时将会终止并退出。

不考虑列队被迫中断的情况,如列队中断将会无条件退出。

com.dewafer.threading.demo.NoneBlockingConsumerRunnerWrapper

在多线程生产者消费者演示中负责将生产者的产物和对应的消费者包装成可在线程上执行的Callable任务。 如消费者不接受该产物将会返回null。

该任务不会中断,不会阻塞。

com.dewafer.threading.demo.RootReduceProcessor

根Reducer处理器。 在任务列表切分研是中负责生产任务列表和将生产的任务列表分配给对应的ReduceTaskImpl以及提交执行。 完成后将等待被切分任务列表执行完成,并将结果合并。

com.dewafer.threading.demo.AbstractListSplittableTask

该抽象基类负责任务列表的切分算法。

首先将尝试切分任务列表,如果任务列表的长度小于某一阈值(THRESHOLD)则不会对任务列表进行切分,直接在当前线程上执行任务列表中的任务。

如果任务列表的长度大于某一阈值(THRESHOLD),则在阈值(THRESHOLD)位置将任务列表切分成左右两个列表,左列表包含第0到阈值位置的元素, 右列表包含所有剩余的元素。

如果列表被切分,则将切分后的右列表提交新线程处理,本线程继续执行处理左列表。

本线程处理完(左)任务列表后,将本列表的处理结果并上右列表提交到的新线程的Future(如果有的话)打包成TaskResult返回。将不会等待其他线程。

com.dewafer.threading.demo.ReduceTaskImpl

针对AbstractListSplittableTask的列表的具体实现。

针对本线程将要处理的列表使用Reducer进行处理。

辅助类

  • com.dewafer.threading.demo.support.Log 负责将System.out打包成简单易用的Log
  • com.dewafer.threading.demo.support.RawProductWrapper 针对列队的包装器,在列队中使用包装器是为了能使用END_OF_QUEUE信号。
  • com.dewafer.threading.demo.support.RunResult 负责收集多次运行的演示结果的Bean
  • com.dewafer.threading.demo.support.TaskResult 负责收集任务列表切分并处理完成后的结果,以及新开线程的Future和负责合并两者的结果。
  • com.dewafer.threading.demo.support.Tuple 负责包装左右列表的元祖Bean

About

多线程演示项目

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages