介紹
享元模式主要用于減少創(chuàng)建對象的數(shù)量帚呼,以減少內(nèi)存占用和提高性能质涛。
使用場景:
1.系統(tǒng)存在大量相似對象认罩。
2.需要對象緩沖池的場景箱蝠。
優(yōu)點:
減少對象的創(chuàng)建,降低系統(tǒng)的內(nèi)存使效率提高垦垂,避免了頻繁GC宦搬。
缺點:
提高了系統(tǒng)的復(fù)雜度,需要分離出外部狀態(tài)和內(nèi)部狀態(tài)劫拗,外部狀態(tài)具有固有化的性質(zhì)间校,不應(yīng)該隨著內(nèi)部狀態(tài)的變化而變化,否則會造成系統(tǒng)的混亂页慷。
UML類圖
外部狀態(tài):此例中是from, to, type憔足。
內(nèi)部狀態(tài):此例中是隨機生成價格。
代碼實現(xiàn)
Ticket.java
public interface Ticket {
public void showTicketInfo();
}
TrainTicket.java
public class TrainTicket implements Ticket {
public String from;
public String to;
public String type;
public int price;
public TrainTicket(String from, String to, String type) {
this.from = from;
this.to = to;
this.type = type;
}
@Override
public void showTicketInfo() {
price = new Random().nextInt(500);
System.out.println("The ticket " + from + " to " + to + " of " + type + " is ¥" + price);
}
}
TicketCenter.java
public class TicketCenter {
static Map<String, Ticket> ticketMap = new ConcurrentHashMap<>();
public static Ticket getTicket(String from, String to, String type) {
String key = from + "-" + to + "-" + type;
if (ticketMap.containsKey(key)) {
System.out.println("Use Cache Ticket ==> " + key);
return ticketMap.get(key);
} else {
System.out.println("Create New Ticket ==> " + key);
Ticket ticket = new TrainTicket(from, to, type);
ticketMap.put(key, ticket);
return ticket;
}
}
}
Main.java
public class Main {
public static void main(String[] args) {
TicketCenter.getTicket("青島", "北京", "硬座").showTicketInfo();
TicketCenter.getTicket("青島", "北京", "硬座").showTicketInfo();
TicketCenter.getTicket("青島", "北京", "軟臥").showTicketInfo();
TicketCenter.getTicket("青島", "煙臺", "硬臥").showTicketInfo();
}
}
輸出
Create New Ticket ==> 青島-北京-硬座
The ticket 青島 to 北京 of 硬座 is 304
Use Cache Ticket ==> 青島-北京-硬座
The ticket 青島 to 北京 of 硬座 is 184
Create New Ticket ==> 青島-北京-軟臥
The ticket 青島 to 北京 of 軟臥 is 485
Create New Ticket ==> 青島-煙臺-硬臥
The ticket 青島 to 煙臺 of 硬臥 is 432