美文网首页并发编程
多线程设计模式:第六篇 - ThreadLocal和Active

多线程设计模式:第六篇 - ThreadLocal和Active

作者: 张angang强吖 | 来源:发表于2018-11-06 18:15 被阅读0次

一,ThreadLocal

        Java 中的 ThreadLocal 类给多线程编程提供了一种可以让每个线程具有自己独立空间的机制,在这个空间内存储的数据是线程特有的,不对外共享。

        ThreadLocal 类提供了 set() 和 get() 方法用于设置和获取线程特有数据,且 ThreadLocal 支持泛型,这样可以通过参数来指定要存储数据的类型。

二,Active Object模式

        Active Object模式的主要目的是实现方法调用和执行分离到不同的线程中,这样可以提高调用方的响应速度,同时执行方的执行策略对调用方透明,达到双方互不干扰。这和之前我们说的生产者-消费者模式,Worker-Thread模式非常相似。

        下面的程序示例,我们选择使用 juc 包中的 Executor 框架来实现一个Active Object模式:

/**
 * @author koma <komazhang@foxmail.com>
 * @date 2018-11-05
 */
public class Main {
    public static void main(String[] args) {
        ActiveObject activeObject = ActiveObjectFactory.createActiveObject();
        try {
            new MakerClientThread("Alice", activeObject).start();
            new MakerClientThread("Bobby", activeObject).start();
            Thread.sleep(5000);
        } catch (RejectedExecutionException e) {
        } catch (InterruptedException e) {
        } finally {
            activeObject.shutdown();
        }
    }
}

public interface ActiveObject {
    public abstract Future<String> makeString(int count, char fillchar);
    public abstract void displayString(String s);
    public abstract void shutdown();
}

public class ActiveObjectFactory {
    public static ActiveObject createActiveObject() {
        return new ActiveObjectImpl();
    }
}

public class ActiveObjectImpl implements ActiveObject {
    private final ExecutorService executorService = Executors.newSingleThreadExecutor();

    @Override
    public Future<String> makeString(final int count, final char fillchar) {
        class MakeStringRequest implements Callable<String> {
            @Override
            public String call() throws Exception { //请求的执行在另外一个线程中异步执行
                char[] buffer = new char[count];
                for (int i = 0; i < count; i++) {
                    buffer[i] = fillchar;
                    try {
                        Thread.sleep(100);
                    } catch (InterruptedException e) {
                        e.printStackTrace();
                    }
                }
                return new String(buffer);
            }
        }
        return executorService.submit(new MakeStringRequest()); //提交请求并马上返回
    }

    @Override
    public void shutdown() {
        executorService.shutdown();
    }
}

public class MakerClientThread extends Thread {
    private final ActiveObject activeObject;
    private final char fillchar;

    public MakerClientThread(String name, ActiveObject activeObject) {
        super(name);
        this.activeObject = activeObject;
        this.fillchar = name.charAt(0);
    }

    @Override
    public void run() {
        try {
            for (int i = 0; true; i++) {
                //使用 Future 模式获取数据
                Future<String> future = activeObject.makeString(i, fillchar);
                Thread.sleep(100);
                String value = future.get();
                System.out.println(Thread.currentThread().getName()+": value = "+value);
            }
        } catch (InterruptedException e) {
        } catch (ExecutionException e) {
        }
    }
}

1,关于 Active Object模式 的说明

        Active Object模式揭示了一个事实即如果可以把方法调用和执行分到不同的线程,即跨越线程界线执行,那么就可以跨越计算机执行,即透过网络在远端计算机上执行方法。与该模式相关的 Java 技术叫 RMI

2,POSA2 中的主动对象(Active Object)设计模式定义

        主动对象(Active Object)设计模式将方法执行和调用分离,加强并发和简化对驻留在自身控制线程中对象的同步访问。

        主动对象 别名 并发对象(Concurrent Object)

相关文章

  • 多线程设计模式:第六篇 - ThreadLocal和Active

    一,ThreadLocal Java 中的 ThreadLocal 类给多线程编程提供了一种可以让每个线程具有自己...

  • Android面试题总结

    1、设计模式2、IPC机制、Binder原理3、多线程、线程中通讯、Volatile、ThreadLocal4、四...

  • ThreadLocal解析以及内存泄露原因、线程不安全情况

    ThreadLocal和Synchonized都用语解决多线程并发访问的,可以ThreadLocal与Syncho...

  • ACTIVE OBJECT 模式

    ACTIVE OBJECT 模式 一.概述 主动对象模式基于命令模式,是实现多线程控制的一项古老的技术。该模式有多...

  • 同步容器

    先了解下ThreadLocal ThreadLocal tl = newThreadLocal<>();多线程情...

  • 并行设计模式(一)-- Future模式

    Java多线程编程中,常用的多线程设计模式包括:Future模式、Master-Worker模式、Guarded ...

  • ThreadLocal

    ThreadLocal 为了编写更优雅的多线程程序 当使用ThreadLocal维护变量时,ThreadLocal...

  • 多线程设计模式

    多线程设计模式学习 参考书目《图解Java多线程设计模式》 [日] 结城浩 著 源程序:https://githu...

  • 单例模式Java篇

    单例设计模式- 饿汉式 单例设计模式 - 懒汉式 单例设计模式 - 懒汉式 - 多线程并发 单例设计模式 - 懒汉...

  • 面试储备

    多线程 想进大厂?50个多线程面试题,你会多少? 设计模式 从 Android 代码中来记忆 23 种设计模式 面...

网友评论

    本文标题:多线程设计模式:第六篇 - ThreadLocal和Active

    本文链接:https://www.haomeiwen.com/subject/ttlyzftx.html