輕松掌握Java享元模式
定義:它使用共享物件,用來盡可能減少內存使用量以及分享資訊給盡可能多的相似物件;它適合用于只是因重復而導致使用無法令人接受的大量內存的大量物件。
特點:大大減少對象的創(chuàng)建,降低系統(tǒng)的內存,使效率提高。
企業(yè)級開發(fā)及常用框架中的應用:數據庫的連接池,String的常量緩存池
具體代碼實例:
import java.util.HashMap; import java.util.Map; import java.util.Random; public class Demo { public static void main(String[] args) { for(int i = 0 ; i < 10 ; i++){ Circle circle = new Circle(getColor()); circle.setRadius(getRadius()); circle.setX(getZ()); circle.setY(getZ()); circle.draw(); } } public static String getColor(){ String[] colors = {"紅色","橙色","黃色","青色","綠色"}; Random random = new Random(); int index = random.nextInt(4); return colors[index]; } public static double getRadius(){ Random random = new Random(); return random.nextDouble()*20; } public static int getZ(){ Random random = new Random(); return random.nextInt(100); } } /** * 抽象享元類 * 這里以畫圖形舉例:比如畫圓,加入顏色固定,畫圓的方式都是一樣的,所不同的就是圓形的位置和圓的半徑 */ interface Shape{ public void draw(); } /** * 具體享元類 * 這里創(chuàng)建具體的享元類,類中包含了可以共享的數據和不可共享的數據 * 例如:可以共享的顏色以及隱形的畫圓方式,不可共享的半徑和坐標 */ class Circle implements Shape{ private int x; private int y; private double radius; private String color; public Circle(String color) { this.color = color; } 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 double getRadius() { return radius; } public void setRadius(double radius) { this.radius = radius; } public String getColor() { return color; } public void setColor(String color) { this.color = color; } public void draw() { System.out.println("畫了一個圓心坐標為:("+this.x+","+this.y+"),半徑為"+this.radius+","+this.color+"的圓"); } } /** * 工廠類:享元模式的具體體現其實是在這一塊得到實現的,在這一塊我們可以清楚的了解到共享了哪些屬性或者數據 * 在這里假設圓的顏色是固定的,我們只能畫固定的幾種顏色的圓 * 在這里例子中對應的共享數據就應該是對應的顏色屬性和隱形的不可見的還原的方式,這個在前面交代過,所有圓的 * 畫的方式是一樣的 */ class CircleFactory{ private static Map<String, Circle> map = new HashMap<>(); public static Circle getCircle(String color){ Circle c = map.get(color); if(c == null){ c = new Circle(color); map.put(color, c); return c; } return c; } }
享元模式主要為了解決大量類似對象占用大量內存的現象,因為內存是珍貴的資源,所以我們講這些相似對象進行歸類,提取出相同部分用以共享,這樣可以非常明顯的節(jié)省內存開銷,但要記住一個前提,在節(jié)省內存的同時,我們是加大了代碼運行時間為前提的,所以,有的時候我們需要平衡時間和內存開銷。
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
Java 詳解循環(huán)屏障CyclicBarrier如何實現多線程分段等待執(zhí)行完成
CyclicBarrier是一個同步工具類,可以翻譯成循環(huán)屏障,也叫障礙器或同步屏障。CyclicBarrier內部有一個計數器count,調用障礙器的await方法會使計數器count的值減一,當計數器count的值為0時,表明調用了await方法線程已經達到了設置的數量2021-11-11mybatis配置Mapper.xml文件時遇到的問題及解決
這篇文章主要介紹了mybatis配置Mapper.xml文件時遇到的問題及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-01-01Java8新特性之類型注解_動力節(jié)點Java學院整理
這篇文章主要介紹了Java8新特性之類型注解的相關資料,需要的朋友可以參考下2017-06-06解決springboot利用ConfigurationProperties注解配置數據源無法讀取配置信息問題
今天在學習springboot利用ConfigurationProperties注解配置數據源的使用遇到一個問題無法讀取配置信息,發(fā)現全部為null,糾結是哪里出了問題呢,今天一番思考,問題根源找到,下面把我的解決方案分享到腳本之家平臺,感興趣的朋友一起看看吧2021-05-05