`
aijuans
  • 浏览: 1569540 次
社区版块
存档分类
最新评论

使用java.util.concurrent.ThreadFactory类创建线程

阅读更多

工厂设计模式是Java中最常用的设计模式之一。它是一种创建型设计模式,能够用于创建一个或多个类所需要的对象。有了这个工厂,我们就能集中的创建对象。

 

集中创建方式给我们带来了一些好处,例如:
1. 能够很容易的改变类创建的对象或者创建对象的方式;
2. 能够很容易限制对象的创建,例如:我们只能为a类创建N个对象;
3. 能够很容易的生成有关对象创建的统计数据。

 

在Java中,我们通常使用两种方式来创建线程:继承Thread类和实现Runnable接口。Java还提供了一个接口,既ThreadFactory接口,用于创建你自己的线程对象工厂。

 

很多类中,例如:ThreadPoolExecutor,使用构造函数来接收ThreadFactory来作为参数。这个工厂参数将会在程序执行时创建新的线程。使用ThreadFactory,你能够自定义执行程序如何创建线程,例如为线程定义适当的名称、优先级,或者你甚至可以将它设定为守护线程。

 

ThreadFactory例子

在这个例子中,我们将学习如何通过实现一个ThreadFactory接口来创建一个有个性化名称的线程对象,同时,我们保存了线程对象的创建信息。

 

Task.java

 

  1. class Task implements Runnable  
  2. {  
  3.    @Override  
  4.    public void run()  
  5.    {  
  6.       try  
  7.       {  
  8.          TimeUnit.SECONDS.sleep(2);  
  9.       } catch (InterruptedException e)  
  10.       {  
  11.          e.printStackTrace();  
  12.       }  
  13.    }  
  14. }  



 

CustomThreadFactory.java

 

 

  1. <span style="font-size:18px;">public class CustomThreadFactory implements ThreadFactory  
  2. {  
  3.    private int          counter;  
  4.    private String       name;  
  5.    private List<String> stats;  
  6.    
  7.    public CustomThreadFactory(String name)  
  8.    {  
  9.       counter = 1;  
  10.       this.name = name;  
  11.       stats = new ArrayList<String>();  
  12.    }  
  13.    
  14.    @Override  
  15.    public Thread newThread(Runnable runnable)  
  16.    {  
  17.       Thread t = new Thread(runnable, name + "-Thread_" + counter);  
  18.       counter++;  
  19.       stats.add(String.format("Created thread %d with name %s on %s \n", t.getId(), t.getName(), new Date()));  
  20.       return t;  
  21.    }  
  22.    
  23.    public String getStats()  
  24.    {  
  25.       StringBuffer buffer = new StringBuffer();  
  26.       Iterator<String> it = stats.iterator();  
  27.       while (it.hasNext())  
  28.       {  
  29.          buffer.append(it.next());  
  30.       }  
  31.       return buffer.toString();  
  32.    }  
  33. }</span>  


为了使用上面的线程工厂,请看下面的执行程序:

 

 

  1. <span style="font-size:18px;">public static void main(String[] args)  
  2. {  
  3.   CustomThreadFactory factory = new CustomThreadFactory("CustomThreadFactory");  
  4.   Task task = new Task();  
  5.   Thread thread;  
  6.   System.out.printf("Starting the Threads\n\n");  
  7.   for (int i = 1; i <= 10; i++)  
  8.   {  
  9.      thread = factory.newThread(task);  
  10.      thread.start();  
  11.   }  
  12.   System.out.printf("All Threads are created now\n\n");  
  13.   System.out.printf("Give me CustomThreadFactory stats:\n\n" + factory.getStats());  
  14. }</span>  


程序执行结果:

 

 

[plain] view plaincopyprint?在CODE上查看代码片派生到我的代码片
 
  1. <span style="font-size:18px;">Output :  
  2.    
  3. Starting the Threads  
  4.    
  5. All Threads are created now  
  6.    
  7. Give me CustomThreadFactory stats:  
  8.    
  9. Created thread 9 with name CustomThreadFactory-Thread_1 on Tue Jan 06 13:18:04 IST 2015  
  10. Created thread 10 with name CustomThreadFactory-Thread_2 on Tue Jan 06 13:18:04 IST 2015  
  11. Created thread 11 with name CustomThreadFactory-Thread_3 on Tue Jan 06 13:18:04 IST 2015  
  12. Created thread 12 with name CustomThreadFactory-Thread_4 on Tue Jan 06 13:18:04 IST 2015  
  13. Created thread 13 with name CustomThreadFactory-Thread_5 on Tue Jan 06 13:18:04 IST 2015  
  14. Created thread 14 with name CustomThreadFactory-Thread_6 on Tue Jan 06 13:18:04 IST 2015  
  15. Created thread 15 with name CustomThreadFactory-Thread_7 on Tue Jan 06 13:18:04 IST 2015  
  16. Created thread 16 with name CustomThreadFactory-Thread_8 on Tue Jan 06 13:18:04 IST 2015  
  17. Created thread 17 with name CustomThreadFactory-Thread_9 on Tue Jan 06 13:18:04 IST 2015  
  18. Created thread 18 with name CustomThreadFactory-Thread_10 on Tue Jan 06 13:18:04 IST 2015</span>  


上面的代码中,ThreadFactory接口只有一个叫做newThread()的方法,它接收一个Runnable对象作为参数,同时返回一个Thread对象。当你实现ThreadFactory接口时,你必须重写这个方法。

其他精彩文章文章

 

jQuery教程(10)-DOM树操作之内容setter和getter方法

android学习笔记(37)使用 DatePickerDialog、TimePickerDialog

 

更多关于android开发文章

1
6
分享到:
评论

相关推荐

    java.util.concurrent.uml.pdf

    例如,ThreadPoolExecutor会使用ThreadFactory来创建线程,它还可能使用RejectedExecutionHandler来处理任务无法加入线程池的情况。ExecutorService提供了提交任务到线程池并返回Future对象的机制,Future对象之后...

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

    1. java.util.concurrent包下的工具类,如CountDownLatch、CyclicBarrier、Semaphore等,用于协调多个线程之间的操作。 以上内容只是《Java多线程编程核心技术》教程中的一部分核心知识点,实际学习中还需要结合...

    java 线程池管理类:Executors_.docx

    `java.util.concurrent.Executors` 继承自 `java.lang.Object`,作为一个工具类,它提供了一系列用于创建和管理线程池的方法,包括`ExecutorService`、`ScheduledExecutorService`、`ThreadFactory`和`Callable`等...

    JAVA使用线程池查询大批量数据

    Java中的线程池主要由`java.util.concurrent`包下的`ExecutorService`接口及其实现类提供。最常见的实现是`ThreadPoolExecutor`,它允许我们自定义线程池的核心参数,如核心线程数、最大线程数、线程存活时间等。...

    jdk1.5 线程并发与线程池的使用

    6. **threadFactory**:用于创建新线程的工厂。 7. **handler**:拒绝策略,当线程池和队列都满时,如何处理新提交的任务。 创建`ThreadPoolExecutor`实例后,可通过`execute()`方法提交`Runnable`任务,或通过`...

    Java多线程.pdf

    Java中保证原子性的机制有synchronized关键字,以及java.util.concurrent包下的atomic类等。 可见性是指当一个线程修改了共享变量的值时,其他线程能够立即看到这一改变。保证可见性的机制包括使用volatile关键字、...

    commons-poo ljar包

    例如,如果我们想要创建一个线程池,我们可以使用`ThreadPool`类,它实现了`ObjectPool`接口并使用`ThreadPoolFactory`来创建和管理线程。以下是一个简单的使用示例: ```java import org.apache.commons.pool2....

    Java多线程设计模式源代码

    1. 工厂模式:用于创建线程对象,如`ThreadFactory`接口。 2. 单例模式:确保只有一个线程实例存在,例如`SingletonThread`。 3. 生产者-消费者模式:使用`BlockingQueue`实现线程间的协作。 4. 状态机模式:表示...

    java并发规范(线程及锁).docx

    推荐使用`Double-Check Locking`或者`java.util.concurrent.atomic.AtomicReference`来实现线程安全的延迟初始化。 遵循这些规范,开发者可以编写出更健壮、高效的并发代码,避免潜在的线程安全问题,提高程序的...

    java之JUC系列.pdf

    JUC(Java.util.concurrent)是Java并发编程库的一个重要组成部分,专门提供了在多线程环境下用于控制并发执行的工具类和接口。本篇内容将详细介绍JUC中的一些核心组件及其使用方法,包括CountDownLatch、Executors...

    PriorityThreadFactory.rar_factory

    `PriorityThreadFactory`类通常会是自定义的实现,扩展了`java.util.concurrent.ThreadFactory`接口。这个接口定义了一个方法`newThread(Runnable r)`,用于创建新的线程。当使用`PriorityThreadFactory`时,创建的...

    aduna-commons-concurrent-2.5.0.jar.zip

    4. **工具类**:Aduna Commons Concurrent还提供了一些实用工具类,如ThreadFactory(线程工厂)和ThreadUncaughtExceptionHandler(未捕获异常处理器),帮助开发者更好地控制线程的创建和异常处理。 5. **执行...

    时间轮Java代码

    3. **ThreadFactory**:用于创建新线程的工厂。 4. **DiscardPolicy**:当添加的任务超过时间轮容量时的策略。 创建实例后,我们可以使用`newTimeout()`方法添加定时任务,该方法接受一个`TimeoutTask`作为参数,该...

    java线程池的源码分析.zip

    首先,我们要理解Java线程池的核心类`java.util.concurrent.ThreadPoolExecutor`,它是所有自定义线程池的基类。线程池通过维护一个工作线程集合来管理任务的执行,避免了频繁创建和销毁线程的开销,提高了系统的...

    JAVA线程池应用.pptx

    - `threadFactory`:创建新线程时使用的工厂。 - `handler`:当拒绝任务时采取的策略。 #### 五、时间单位与阻塞队列 - **TimeUnit**:表示时间单位的枚举类,包含DAYS、HOURS、MINUTES、SECONDS、MILLISECONDS、...

    Java聊天室程序(java).zip

    因此,理解并发控制机制如`synchronized`关键字、`java.util.concurrent`包中的工具类(如Semaphore、CyclicBarrier)是非常重要的。正确地管理并发能防止数据竞争,确保数据的一致性。 4. **IO流**:Java的IO流...

    L16-多线程和线程同步-讲义.pdf

    `ThreadFactory`接口用于创建自定义的线程,如示例所示,它有一个`newThread(Runnable r)`方法,可以自定义线程的名称或其他属性。`Executor`框架提供了一种更灵活的方式来管理线程,例如`Executors....

    聊聊并发(3)Java线程池的分析和使用Java开发Jav

    5. **threadFactory**:用于创建新线程的工厂,可以自定义线程属性。 6. **handler**:拒绝策略,当线程池和工作队列都满时,用于处理新提交的任务。 在实际开发中,我们可以根据应用场景选择合适的线程池实现。...

    java 线程池

    6. **线程工厂(ThreadFactory)**:用于创建新线程,可以自定义线程的命名、线程优先级等属性。 7. **拒绝策略(RejectedExecutionHandler)**:当线程池和任务队列都满时,新任务的处理策略。常见的策略有抛出异常...

    Java 线程池的原理与实现

    - **Java内置线程池**:Java通过`java.util.concurrent`包中的`ExecutorService`接口及其实现类如`ThreadPoolExecutor`提供了线程池的实现。`ThreadPoolExecutor`允许自定义线程池的核心参数,如核心线程数、最大...

Global site tag (gtag.js) - Google Analytics