工厂设计模式是Java中最常用的设计模式之一。它是一种创建型设计模式,能够用于创建一个或多个类所需要的对象。有了这个工厂,我们就能集中的创建对象。
集中创建方式给我们带来了一些好处,例如:
1. 能够很容易的改变类创建的对象或者创建对象的方式;
2. 能够很容易限制对象的创建,例如:我们只能为a类创建N个对象;
3. 能够很容易的生成有关对象创建的统计数据。
在Java中,我们通常使用两种方式来创建线程:继承Thread类和实现Runnable接口。Java还提供了一个接口,既ThreadFactory接口,用于创建你自己的线程对象工厂。
很多类中,例如:ThreadPoolExecutor,使用构造函数来接收ThreadFactory来作为参数。这个工厂参数将会在程序执行时创建新的线程。使用ThreadFactory,你能够自定义执行程序如何创建线程,例如为线程定义适当的名称、优先级,或者你甚至可以将它设定为守护线程。
ThreadFactory例子
在这个例子中,我们将学习如何通过实现一个ThreadFactory接口来创建一个有个性化名称的线程对象,同时,我们保存了线程对象的创建信息。
Task.java
- class Task implements Runnable
- {
- @Override
- public void run()
- {
- try
- {
- TimeUnit.SECONDS.sleep(2);
- } catch (InterruptedException e)
- {
- e.printStackTrace();
- }
- }
- }
CustomThreadFactory.java
- <span style="font-size:18px;">public class CustomThreadFactory implements ThreadFactory
- {
- private int counter;
- private String name;
- private List<String> stats;
- public CustomThreadFactory(String name)
- {
- counter = 1;
- this.name = name;
- stats = new ArrayList<String>();
- }
- @Override
- public Thread newThread(Runnable runnable)
- {
- Thread t = new Thread(runnable, name + "-Thread_" + counter);
- counter++;
- stats.add(String.format("Created thread %d with name %s on %s \n", t.getId(), t.getName(), new Date()));
- return t;
- }
- public String getStats()
- {
- StringBuffer buffer = new StringBuffer();
- Iterator<String> it = stats.iterator();
- while (it.hasNext())
- {
- buffer.append(it.next());
- }
- return buffer.toString();
- }
- }</span>
为了使用上面的线程工厂,请看下面的执行程序:
- <span style="font-size:18px;">public static void main(String[] args)
- {
- CustomThreadFactory factory = new CustomThreadFactory("CustomThreadFactory");
- Task task = new Task();
- Thread thread;
- System.out.printf("Starting the Threads\n\n");
- for (int i = 1; i <= 10; i++)
- {
- thread = factory.newThread(task);
- thread.start();
- }
- System.out.printf("All Threads are created now\n\n");
- System.out.printf("Give me CustomThreadFactory stats:\n\n" + factory.getStats());
- }</span>
程序执行结果:
- <span style="font-size:18px;">Output :
- Starting the Threads
- All Threads are created now
- Give me CustomThreadFactory stats:
- Created thread 9 with name CustomThreadFactory-Thread_1 on Tue Jan 06 13:18:04 IST 2015
- Created thread 10 with name CustomThreadFactory-Thread_2 on Tue Jan 06 13:18:04 IST 2015
- Created thread 11 with name CustomThreadFactory-Thread_3 on Tue Jan 06 13:18:04 IST 2015
- Created thread 12 with name CustomThreadFactory-Thread_4 on Tue Jan 06 13:18:04 IST 2015
- Created thread 13 with name CustomThreadFactory-Thread_5 on Tue Jan 06 13:18:04 IST 2015
- Created thread 14 with name CustomThreadFactory-Thread_6 on Tue Jan 06 13:18:04 IST 2015
- Created thread 15 with name CustomThreadFactory-Thread_7 on Tue Jan 06 13:18:04 IST 2015
- Created thread 16 with name CustomThreadFactory-Thread_8 on Tue Jan 06 13:18:04 IST 2015
- Created thread 17 with name CustomThreadFactory-Thread_9 on Tue Jan 06 13:18:04 IST 2015
- 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开发文章
相关推荐
例如,ThreadPoolExecutor会使用ThreadFactory来创建线程,它还可能使用RejectedExecutionHandler来处理任务无法加入线程池的情况。ExecutorService提供了提交任务到线程池并返回Future对象的机制,Future对象之后...
1. java.util.concurrent包下的工具类,如CountDownLatch、CyclicBarrier、Semaphore等,用于协调多个线程之间的操作。 以上内容只是《Java多线程编程核心技术》教程中的一部分核心知识点,实际学习中还需要结合...
`java.util.concurrent.Executors` 继承自 `java.lang.Object`,作为一个工具类,它提供了一系列用于创建和管理线程池的方法,包括`ExecutorService`、`ScheduledExecutorService`、`ThreadFactory`和`Callable`等...
Java中的线程池主要由`java.util.concurrent`包下的`ExecutorService`接口及其实现类提供。最常见的实现是`ThreadPoolExecutor`,它允许我们自定义线程池的核心参数,如核心线程数、最大线程数、线程存活时间等。...
6. **threadFactory**:用于创建新线程的工厂。 7. **handler**:拒绝策略,当线程池和队列都满时,如何处理新提交的任务。 创建`ThreadPoolExecutor`实例后,可通过`execute()`方法提交`Runnable`任务,或通过`...
例如,如果我们想要创建一个线程池,我们可以使用`ThreadPool`类,它实现了`ObjectPool`接口并使用`ThreadPoolFactory`来创建和管理线程。以下是一个简单的使用示例: ```java import org.apache.commons.pool2....
1. 工厂模式:用于创建线程对象,如`ThreadFactory`接口。 2. 单例模式:确保只有一个线程实例存在,例如`SingletonThread`。 3. 生产者-消费者模式:使用`BlockingQueue`实现线程间的协作。 4. 状态机模式:表示...
推荐使用`Double-Check Locking`或者`java.util.concurrent.atomic.AtomicReference`来实现线程安全的延迟初始化。 遵循这些规范,开发者可以编写出更健壮、高效的并发代码,避免潜在的线程安全问题,提高程序的...
JUC(Java.util.concurrent)是Java并发编程库的一个重要组成部分,专门提供了在多线程环境下用于控制并发执行的工具类和接口。本篇内容将详细介绍JUC中的一些核心组件及其使用方法,包括CountDownLatch、Executors...
`PriorityThreadFactory`类通常会是自定义的实现,扩展了`java.util.concurrent.ThreadFactory`接口。这个接口定义了一个方法`newThread(Runnable r)`,用于创建新的线程。当使用`PriorityThreadFactory`时,创建的...
4. **工具类**:Aduna Commons Concurrent还提供了一些实用工具类,如ThreadFactory(线程工厂)和ThreadUncaughtExceptionHandler(未捕获异常处理器),帮助开发者更好地控制线程的创建和异常处理。 5. **执行...
3. **ThreadFactory**:用于创建新线程的工厂。 4. **DiscardPolicy**:当添加的任务超过时间轮容量时的策略。 创建实例后,我们可以使用`newTimeout()`方法添加定时任务,该方法接受一个`TimeoutTask`作为参数,该...
首先,我们要理解Java线程池的核心类`java.util.concurrent.ThreadPoolExecutor`,它是所有自定义线程池的基类。线程池通过维护一个工作线程集合来管理任务的执行,避免了频繁创建和销毁线程的开销,提高了系统的...
- `threadFactory`:创建新线程时使用的工厂。 - `handler`:当拒绝任务时采取的策略。 #### 五、时间单位与阻塞队列 - **TimeUnit**:表示时间单位的枚举类,包含DAYS、HOURS、MINUTES、SECONDS、MILLISECONDS、...
因此,理解并发控制机制如`synchronized`关键字、`java.util.concurrent`包中的工具类(如Semaphore、CyclicBarrier)是非常重要的。正确地管理并发能防止数据竞争,确保数据的一致性。 4. **IO流**:Java的IO流...
`ThreadFactory`接口用于创建自定义的线程,如示例所示,它有一个`newThread(Runnable r)`方法,可以自定义线程的名称或其他属性。`Executor`框架提供了一种更灵活的方式来管理线程,例如`Executors....
5. **threadFactory**:用于创建新线程的工厂,可以自定义线程属性。 6. **handler**:拒绝策略,当线程池和工作队列都满时,用于处理新提交的任务。 在实际开发中,我们可以根据应用场景选择合适的线程池实现。...
6. **线程工厂(ThreadFactory)**:用于创建新线程,可以自定义线程的命名、线程优先级等属性。 7. **拒绝策略(RejectedExecutionHandler)**:当线程池和任务队列都满时,新任务的处理策略。常见的策略有抛出异常...
- **Java内置线程池**:Java通过`java.util.concurrent`包中的`ExecutorService`接口及其实现类如`ThreadPoolExecutor`提供了线程池的实现。`ThreadPoolExecutor`允许自定义线程池的核心参数,如核心线程数、最大...