`
廖世勇
  • 浏览: 100872 次
  • 性别: Icon_minigender_1
  • 来自: 湖南郴州
社区版块
存档分类
最新评论

JAVA多线程

 
阅读更多


ThreadPoolService(线程池服务类):这是线程池最核心的一个类。它在被创建了时候就创建了几个线程对象,但是这些线程并没有启动运行,但调用了start()方法启动线程池服务时,它们才真正运行。stop()方法可以停止线程池服务,同时停止池中所有线程的运行。而runTask(Tasktask)方法是将一个新的待执行任务交与线程池来运行。
ThreadPoolService类的定义如下:

Java代码

  1. import java.util.ArrayList;
  2. import java.util.List;
  3. public class ThreadPoolService {
  4. // 线程数
  5. public static final int THREAD_COUNT = 5;
  6. // 线程池状态
  7. private Status status = Status.NEW;
  8. private TaskQueue queue = new TaskQueue();
  9. public enum Status {
  10. /* 新建 */NEW, /* 提供服务中 */RUNNING, /* 停止服务 */TERMINATED,
  11. }
  12. private List<Thread> threads = new ArrayList<Thread>();
  13. public ThreadPoolService() {
  14. for (int i = 0; i < THREAD_COUNT; i++) {
  15. Thread t = new TaskThread(this);
  16. threads.add(t);
  17. }
  18. }
  19. // 启动服务
  20. public void start() {


[/list]
完成了上面四个类,我们就实现了一个简单的线程池。现在我们就可以使用它了,下面的代码做了一个简单的示例:

Java代码

  1. public class SimpleTaskTest extends Task {
  2. @Override
  3. public void deal() {
  4. // do something
  5. }
  6. public static void main(String[] args) throws InterruptedException {
  7. ThreadPoolService service = new ThreadPoolService();
  8. service.start();
  9. // 执行十次任务
  10. for (int i = 0; i < 10; i++) {
  11. service.runTask(new SimpleTaskTest());
  12. }
  13. // 睡眠1秒钟,等待所有任务执行完毕
  14. Thread.sleep(1000);
  15. service.stop();
  16. }
  17. }

public class SimpleTaskTest extends Task {

@Override

public void deal() {

// do something

}

public static void main(String[] args) throws InterruptedException {

ThreadPoolService service = new ThreadPoolService();

service.start();

// 执行十次任务

for (int i = 0; i < 10; i++) {

service.runTask(new SimpleTaskTest());

}

// 睡眠1秒钟,等待所有任务执行完毕

Thread.sleep(1000);

service.stop();

}

}


当然,我们实现的是最简单的,这里只是为了演示线程池的实现原理。在实际应用中,根据情况的不同,可以做很多优化。比如:

  • 调整任务队列的规则,给任务设置优先级,级别高的任务优先执行。
  • 动态维护线程池,当待执行任务数量较多时,增加线程的数量,加快任务的执行速度;当任务较少时,回收一部分长期闲置的线程,减少对系统资源的消耗。


事实上Java5.0及以上版本已经为我们提供了线程池功能,无需再重新实现。这些类位于java.util.concurrent包中。

Executors类提供了一组创建线程池对象的方法,常用的有一下几个:

Java代码

  1. public static ExecutorService newCachedThreadPool() {
  2. // other code
  3. }
  4. public static ExecutorService newFixedThreadPool(int nThreads) {
  5. // other code
  6. }
  7. public static ExecutorService newSingleThreadExecutor() {
  8. // other code
  9. }

public static ExecutorService newCachedThreadPool() {

// other code

}

public static ExecutorService newFixedThreadPool(int nThreads) {

// other code

}

public static ExecutorService newSingleThreadExecutor() {

// other code

}


newCachedThreadPool()方法创建一个动态的线程池,其中线程的数量会根据实际需要来创建和回收,适合于执行大量短期任务的情况;newFixedThreadPool(int nThreads)方法创建一个包含固定数量线程对象的线程池,nThreads代表要创建的线程数,如果某个线程在运行的过程中因为异常而终止了,那么一个新的线程会被创建和启动来代替它;而newSingleThreadExecutor()方法则只在线程池中创建一个线程,来执行所有的任务。

这三个方法都返回了一个ExecutorService类型的对象。实际上,ExecutorService是一个接口,它的submit()方法负责接收任务并交与线程池中的线程去运行。submit()方法能够接受Callable和Runnable两种类型的对象。它们的用法和区别如下:

  1. Runnable接口:继承Runnable接口的类要实现它的run()方法,并将执行任务的代码放入其中,run()方法没有返回值。适合于只做某种操作,不关心运行结果的情况。
  2. Callable接口:继承Callable接口的类要实现它的call()方法,并将执行任务的代码放入其中,call()将任务的执行结果作为返回值。适合于执行某种操作后,需要知道执行结果的情况。


无论是接收Runnable型参数,还是接收Callable型参数的submit()方法,都会返回一个Future(也是一个接口)类型的对象。该对象中包含了任务的执行情况以及结果。调用Future的boolean isDone()方法可以获知任务是否执行完毕;调用Object get()方法可以获得任务执行后的返回结果,如果此时任务还没有执行完,get()方法会保持等待,直到相应的任务执行完毕后,才会将结果返回。

我们用下面的一个例子来演示Java5.0中线程池的使用:

Java代码

  1. import java.util.concurrent.*;
  2. public class ExecutorTest {
  3. public static void main(String[] args) throws InterruptedException,
  4. ExecutionException {
  5. ExecutorService es = Executors.newSingleThreadExecutor();
  6. Future fr = es.submit(new RunnableTest());// 提交任务
  7. Future fc = es.submit(new CallableTest());// 提交任务
  8. // 取得返回值并输出
  9. System.out.println((String) fc.get());
  10. // 检查任务是否执行完毕
  11. if (fr.isDone()) {
  12. System.out.println("执行完毕-RunnableTest.run()");
  13. } else {
  14. System.out.println("未执行完-RunnableTest.run()");
  15. }
  16. // 检查任务是否执行完毕
  17. if (fc.isDone()) {
  18. System.out.println("执行完毕-CallableTest.run()");
  19. } else {
  20. System.out.println("未执行完-CallableTest.run()");
  21. }
  22. // 停止线程池服务
  23. es.shutdown();
  24. }
  25. }
  26. class RunnableTest implements Runnable {
  27. public void run() {
  28. System.out.println("已经执行-RunnableTest.run()");
  29. }
  30. }
  31. class CallableTest implements Callable {
  32. public Object call() {
  33. System.out.println("已经执行-CallableTest.call()");
  34. return "返回值-CallableTest.call()";
  35. }
  36. }

import java.util.concurrent.*;

public class ExecutorTest {

public static void main(String[] args) throws InterruptedException,

ExecutionException {

ExecutorService es = Executors.newSingleThreadExecutor();

Future fr = es.submit(new RunnableTest());// 提交任务

Future fc = es.submit(new CallableTest());// 提交任务

// 取得返回值并输出

System.out.println((String) fc.get());

// 检查任务是否执行完毕

if (fr.isDone()) {

System.out.println("执行完毕-RunnableTest.run()");

} else {

System.out.println("未执行完-RunnableTest.run()");

}

// 检查任务是否执行完毕

if (fc.isDone()) {

System.out.println("执行完毕-CallableTest.run()");

} else {

System.out.println("未执行完-CallableTest.run()");

}

// 停止线程池服务

es.shutdown();

}

}

class RunnableTest implements Runnable {

public void run() {

System.out.println("已经执行-RunnableTest.run()");

}

}

class CallableTest implements Callable {

public Object call() {

System.out.println("已经执行-CallableTest.call()");

return "返回值-CallableTest.call()";

}

}


运行结果:

  1. 已经执行-RunnableTest.run()
  2. 已经执行-CallableTest.call()
  3. 返回值-CallableTest.call()
  4. 执行完毕-RunnableTest.run()
  5. 执行完毕-CallableTest.run()

使用完线程池之后,需要调用它的shutdown()方法停止服务,否则其中的所有线程都会保持运行,程序不会退出。

(转载http://zangweiren.javaeye.com

分享到:
评论

相关推荐

    Java多线程知识点总结

    Java多线程是Java编程语言中一个非常重要的概念,它允许开发者在一个程序中创建多个执行线程并行运行,以提高程序的执行效率和响应速度。在Java中,线程的生命周期包含五个基本状态,分别是新建状态(New)、就绪...

    java 多线程操作数据库

    ### Java多线程操作数据库:深入解析与应用 在当今高度并发的应用环境中,Java多线程技术被广泛应用于处理数据库操作,以提升系统的响应速度和处理能力。本文将基于一个具体的Java多线程操作数据库的应用程序,深入...

    Java多线程设计模式上传文件

    Java多线程设计模式上传文件Java多线程设计模式上传文件Java多线程设计模式上传文件Java多线程设计模式上传文件Java多线程设计模式上传文件Java多线程设计模式上传文件Java多线程设计模式上传文件Java多线程设计模式...

    java多线程经典案例

    Java多线程是Java编程中的重要概念,它允许程序同时执行多个任务,极大地提升了程序的效率和性能。在Java中,实现多线程有两种主要方式:通过实现Runnable接口或者继承Thread类。本案例将深入探讨Java多线程中的关键...

    java多线程Demo

    Java多线程是Java编程中的一个重要概念,它允许程序同时执行多个任务,提高了程序的效率和响应速度。在Java中,实现多线程有两种主要方式:继承Thread类和实现Runnable接口。 1. 继承Thread类: 当我们创建一个新...

    java多线程的讲解和实战

    Java多线程是Java编程中的重要概念,尤其在如今的多核处理器环境下,理解并熟练掌握多线程技术对于提高程序性能和响应速度至关重要。本资料详细讲解了Java多线程的原理,并提供了丰富的实战代码,非常适合Java初学者...

    java多线程分页查询

    ### Java多线程分页查询知识点详解 #### 一、背景与需求分析 在实际的软件开发过程中,尤其是在处理大量数据时,如何高效地进行数据查询成为了一个关键问题。例如,在一个用户众多的社交平台上,当用户需要查看...

    汪文君JAVA多线程编程实战(完整不加密)

    《汪文君JAVA多线程编程实战》是一本专注于Java多线程编程的实战教程,由知名讲师汪文君倾力打造。这本书旨在帮助Java开发者深入理解和熟练掌握多线程编程技术,提升软件开发的效率和质量。在Java平台中,多线程是...

    java多线程ppt

    java多线程PPT 多线程基本概念 创建线程的方式 线程的挂起与唤醒 多线程问题

    java多线程读取文件

    Java多线程读大文件 java多线程写文件:多线程往队列中写入数据

    Java多线程机制(讲述java里面与多线程有关的函数)

    Java多线程机制是Java编程中至关重要的一部分,它允许程序同时执行多个任务,提升应用程序的效率和响应性。以下是对各个知识点的详细说明: 9.1 Java中的线程: Java程序中的线程是在操作系统级别的线程基础上进行...

    深入浅出 Java 多线程.pdf

    在本文中,我们将深入浅出Java多线程编程的世界,探索多线程编程的基本概念、多线程编程的优点、多线程编程的缺点、多线程编程的应用场景、多线程编程的实现方法等内容。 一、多线程编程的基本概念 多线程编程是指...

    java 多线程并发实例

    在Java编程中,多线程并发是提升程序执行效率、充分利用多核处理器资源的重要手段。本文将基于"java 多线程并发实例"这个主题,深入探讨Java中的多线程并发概念及其应用。 首先,我们要了解Java中的线程。线程是...

    java多线程实现大批量数据导入源码

    本项目以"java多线程实现大批量数据导入源码"为题,旨在通过多线程策略将大量数据切分,并进行并行处理,以提高数据处理速度。 首先,我们需要理解Java中的线程机制。Java通过`Thread`类来创建和管理线程。每个线程...

    JAVAJAVA多线程教学演示系统论文

    《JAVA多线程教学演示系统》是一篇深入探讨JAVA多线程编程的论文,它针对教育领域中的教学需求,提供了一种生动、直观的演示方式,帮助学生更好地理解和掌握多线程技术。这篇论文的核心内容可能包括以下几个方面: ...

    java多线程查询数据库

    综上所述,"java多线程查询数据库"是一个涉及多线程技术、线程池管理、并发控制、分页查询等多个方面的复杂问题。通过理解和掌握这些知识点,我们可以有效地提高数据库操作的效率和系统的响应速度。

    java 多线程编程实战指南(核心 + 设计模式 完整版)

    《Java多线程编程实战指南》这本书深入浅出地讲解了Java多线程的核心概念和实战技巧,分为核心篇和设计模式篇,旨在帮助开发者掌握并应用多线程技术。 1. **线程基础** - **线程的创建**:Java提供了两种创建线程...

    JAVA多线程编程技术PDF

    这份“JAVA多线程编程技术PDF”是学习和掌握这一领域的经典资料,涵盖了多线程的全部知识点。 首先,多线程的核心概念包括线程的创建与启动。在Java中,可以通过实现Runnable接口或继承Thread类来创建线程。创建后...

    Java多线程编程核心技术_完整版_java_

    Java多线程编程是Java开发中的重要组成部分,它允许程序同时执行多个任务,极大地提高了程序的效率和响应性。在Java中,多线程主要通过继承Thread类或实现Runnable接口来实现。本教程《Java多线程编程核心技术》将...

    Java多线程编程实战指南(核心篇)

    Java多线程编程实战指南(核心篇) 高清pdf带目录 随着现代处理器的生产工艺从提升处理器主频频率转向多核化,即在一块芯片上集成多个处理器内核(Core),多核处理器(Multicore Processor)离我们越来越近了――如今...

Global site tag (gtag.js) - Google Analytics