1 享元模式
1.1 概念
1、定义
2、优点
- 如果系统有大量类似的对象,可以节省大量的内存及CPU资源。
3、应用
- JDK源码:String、Integer、Long……
1.2 实现
package com.xianhuii.designpattern.flyweight;
import java.util.Map;
import java.util.concurrent.ConcurrentHashMap;
public class Flyweight {
public static void main(String[] args) {
TreeNode treeNode1 = new TreeNode(0, 4, TreeFactory.getTree("xxx", "xxxxxx"));
TreeNode treeNode2 = new TreeNode(1, 4, TreeFactory.getTree("xxx", "xxxxxx"));
TreeNode treeNode3 = new TreeNode(2, 4, TreeFactory.getTree("yyy", "xxxxxx"));
TreeNode treeNode4 = new TreeNode(3, 4, TreeFactory.getTree("yyy", "xxxxxx"));
}
}
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;
}
public int getX() {
return x;
}
public void setX(int x) {
this.x = x;
}
public int getY() {
return y;
}
public void setY(int y) {
this.y = y;
}
public Tree getTree() {
return tree;
}
public void setTree(Tree tree) {
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;
}
}
class Tree {
private final String name;
private final String data;
public Tree(String name, String data) {
System.out.println("name:" + name + " created");
this.name = name;
this.data = data;
}
public String getName() {
return name;
}
public String getData() {
return data;
}
}