1. 定义

运用共享技术有效地支持大量细粒度的对象。

2. 实现

2.1 Tree、TreeNode、TreeFactory

  1. class Tree {
  2. //设置final保证线程安全
  3. private final String name;
  4. private final String data;
  5. public Tree(String name, String data) {
  6. this.name = name;
  7. this.data = data;
  8. }
  9. public String getName() {
  10. return name;
  11. }
  12. public String getData() {
  13. return data;
  14. }
  15. }
  1. class TreeNode {
  2. private int x;
  3. private int y;
  4. private Tree tree;
  5. public TreeNode(int x, int y, Tree tree) {
  6. this.x = x;
  7. this.y = y;
  8. this.tree = tree;
  9. }
  10. public int getX() {
  11. return x;
  12. }
  13. public void setX(int x) {
  14. this.x = x;
  15. }
  16. public int getY() {
  17. return y;
  18. }
  19. public void setY(int y) {
  20. this.y = y;
  21. }
  22. public Tree getTree() {
  23. return tree;
  24. }
  25. public void setTree(Tree tree) {
  26. this.tree = tree;
  27. }
  28. }
  1. class TreeFactory {
  2. //ConcurrentHashMap保证线程安全
  3. private static Map<String, Tree> map = new ConcurrentHashMap<>();
  4. public static Tree getTree(String name, String data) {
  5. if (map.containsKey(name)) {
  6. return map.get(name);
  7. }
  8. Tree tree = new Tree(name, data);
  9. map.put(name, tree);
  10. return tree;
  11. }
  12. }

2.2 使用

  1. public static void main(String[] args) {
  2. //TreeFactory.getTree获取的到数据只会实例化一次,就达到数据共享目的
  3. TreeNode treeNode1 = new TreeNode(3, 4, TreeFactory.getTree("xxx", "xxxxxxx"));
  4. TreeNode treeNode2 = new TreeNode(5, 9, TreeFactory.getTree("xxx", "xxxxxxx"));
  5. }

3. 优点

如果系统有大量类似的对象,可以节省大量的内存及CPU资源

4. JDK源码应用

  1. String,Integer,Long...
  2. com.sun.org.apache.bcel.internal.generic.InstructionConstants