设计模式-享元模式

享元模式:运用共享技术有效的支持大量细粒度的对象

 

import java.util.Map;
import java.util.concurrent.ConcurrentHashMap;

/**
 * 享元模式
 */
public class FlyWeightTest {
    public static void main(String[] args) {
        TreeNode treeNode1 = new TreeNode(3, 4, TreeFactory.getTree("xxx", "xxxxxxxx"));
        TreeNode treeNode2 = new TreeNode(5, 4, TreeFactory.getTree("xxx", "xxxxxxxx"));

        TreeNode treeNode3 = new TreeNode(32, 41, TreeFactory.getTree("yyy", "xxxxxxxx"));
        TreeNode treeNode4 = new TreeNode(53, 44, TreeFactory.getTree("yyy", "xxxxxxxx"));

    }

}

class Tree{
    private final String name;
    private final String data;

    public Tree(String name, String data) {
        System.out.println("name:" + name + "data" + data);
        this.name = name;
        this.data = data;
    }

    public String getName() {
        return name;
    }

    public String getData() {
        return data;
    }
}

class TreeNode{
    private int x;
    private int y;
    private Tree tree;

    public TreeNode(int x, int y, Tree tree) {
        this.x = x;
        this.y = y;
        this.tree = tree;
    }


}

class TreeFactory{
    private static Map<String,Tree> map = new ConcurrentHashMap<>();

    public static Tree getTree(String name, String data){
        if (map.containsKey(name)){
            return map.get(name);
        }
        Tree tree = new Tree(name, data);
        map.put(name,tree);
        return tree;
    }
}

 

posted @ 2021-05-19 21:56  炼金术士0z  阅读(48)  评论(0编辑  收藏  举报