java中優(yōu)化大量if...else...方法總結(jié)
策略模式(Strategy Pattern)
將每個條件分支的實現(xiàn)作為一個獨立的策略類,然后使用一個上下文對象來選擇要執(zhí)行的策略。這種方法可以將大量的if else語句轉(zhuǎn)換為對象之間的交互,從而提高代碼的可維護性和可擴展性。
示例:
首先,我們定義一個接口來實現(xiàn)所有策略的行為:
public interface PaymentStrategy {
void pay(double amount);
}接下來,我們定義具體的策略類來實現(xiàn)不同的支付方式:
public class CreditCardPaymentStrategy implements PaymentStrategy {
private String name;
private String cardNumber;
private String cvv;
private String dateOfExpiry;
public CreditCardPaymentStrategy(String name, String cardNumber, String cvv, String dateOfExpiry) {
this.name = name;
this.cardNumber = cardNumber;
this.cvv = cvv;
this.dateOfExpiry = dateOfExpiry;
}
public void pay(double amount) {
System.out.println(amount + " paid with credit card");
}
}
public class PayPalPaymentStrategy implements PaymentStrategy {
private String emailId;
private String password;
public PayPalPaymentStrategy(String emailId, String password) {
this.emailId = emailId;
this.password = password;
}
public void pay(double amount) {
System.out.println(amount + " paid using PayPal");
}
}
public class CashPaymentStrategy implements PaymentStrategy {
public void pay(double amount) {
System.out.println(amount + " paid in cash");
}
}現(xiàn)在,我們可以在客戶端代碼中創(chuàng)建不同的策略對象,并將它們傳遞給一個統(tǒng)一的支付類中,這個支付類會根據(jù)傳入的策略對象來調(diào)用相應的支付方法:
public class ShoppingCart {
private List<Item> items;
public ShoppingCart() {
this.items = new ArrayList<>();
}
public void addItem(Item item) {
this.items.add(item);
}
public void removeItem(Item item) {
this.items.remove(item);
}
public double calculateTotal() {
double sum = 0;
for (Item item : items) {
sum += item.getPrice();
}
return sum;
}
public void pay(PaymentStrategy paymentStrategy) {
double amount = calculateTotal();
paymentStrategy.pay(amount);
}
}現(xiàn)在我們可以使用上述代碼來創(chuàng)建一個購物車,向其中添加一些商品,然后使用不同的策略來支付:
public class Main {
public static void main(String[] args) {
ShoppingCart cart = new ShoppingCart();
Item item1 = new Item("1234", 10);
Item item2 = new Item("5678", 40);
cart.addItem(item1);
cart.addItem(item2);
// pay by credit card
cart.pay(new CreditCardPaymentStrategy("John Doe", "1234567890123456", "786", "12/22"));
// pay by PayPal
cart.pay(new PayPalPaymentStrategy("myemail@example.com", "mypassword"));
// pay in cash
cart.pay(new CashPaymentStrategy());
//--------------------------或者提前將不同的策略對象放入map當中,如下
Map<String, PaymentStrategy> paymentStrategies = new HashMap<>();
paymentStrategies.put("creditcard", new CreditCardPaymentStrategy("John Doe", "1234567890123456", "786", "12/22"));
paymentStrategies.put("paypal", new PayPalPaymentStrategy("myemail@example.com", "mypassword"));
paymentStrategies.put("cash", new CashPaymentStrategy());
String paymentMethod = "creditcard"; // 用戶選擇的支付方式
PaymentStrategy paymentStrategy = paymentStrategies.get(paymentMethod);
cart.pay(paymentStrategy);
}
}工廠模式(Factory Pattern)
將每個條件分支的實現(xiàn)作為一個獨立的產(chǎn)品類,然后使用一個工廠類來創(chuàng)建具體的產(chǎn)品對象。這種方法可以將大量的if else語句轉(zhuǎn)換為對象的創(chuàng)建過程,從而提高代碼的可讀性和可維護性。
示例:
// 定義一個接口
public interface StringProcessor {
public void processString(String str);
}
// 實現(xiàn)接口的具體類
public class LowercaseStringProcessor implements StringProcessor {
public void processString(String str) {
System.out.println(str.toLowerCase());
}
}
public class UppercaseStringProcessor implements StringProcessor {
public void processString(String str) {
System.out.println(str.toUpperCase());
}
}
public class ReverseStringProcessor implements StringProcessor {
public void processString(String str) {
StringBuilder sb = new StringBuilder(str);
System.out.println(sb.reverse().toString());
}
}
// 工廠類
public class StringProcessorFactory {
public static StringProcessor createStringProcessor(String type) {
if (type.equals("lowercase")) {
return new LowercaseStringProcessor();
} else if (type.equals("uppercase")) {
return new UppercaseStringProcessor();
} else if (type.equals("reverse")) {
return new ReverseStringProcessor();
}
throw new IllegalArgumentException("Invalid type: " + type);
}
}
// 測試代碼
public class Main {
public static void main(String[] args) {
StringProcessor sp1 = StringProcessorFactory.createStringProcessor("lowercase");
sp1.processString("Hello World");
StringProcessor sp2 = StringProcessorFactory.createStringProcessor("uppercase");
sp2.processString("Hello World");
StringProcessor sp3 = StringProcessorFactory.createStringProcessor("reverse");
sp3.processString("Hello World");
}
}看起來還是有if...else,但這樣的代碼更加簡潔易懂,后期也便于維護....
映射表(Map)
使用一個映射表來將條件分支的實現(xiàn)映射到對應的函數(shù)或方法上。這種方法可以減少代碼中的if else語句,并且可以動態(tài)地更新映射表,從而提高代碼的靈活性和可維護性。
示例:
import java.util.HashMap;
import java.util.Map;
import java.util.function.Function;
public class MappingTableExample {
private Map<String, Function<Integer, Integer>> functionMap;
public MappingTableExample() {
functionMap = new HashMap<>();
functionMap.put("add", x -> x + 1);
functionMap.put("sub", x -> x - 1);
functionMap.put("mul", x -> x * 2);
functionMap.put("div", x -> x / 2);
}
public int calculate(String operation, int input) {
if (functionMap.containsKey(operation)) {
return functionMap.get(operation).apply(input);
} else {
throw new IllegalArgumentException("Invalid operation: " + operation);
}
}
public static void main(String[] args) {
MappingTableExample example = new MappingTableExample();
System.out.println(example.calculate("add", 10));
System.out.println(example.calculate("sub", 10));
System.out.println(example.calculate("mul", 10));
System.out.println(example.calculate("div", 10));
System.out.println(example.calculate("mod", 10)); // 拋出異常
}
}數(shù)據(jù)驅(qū)動設(shè)計(Data-Driven Design)
將條件分支的實現(xiàn)和輸入數(shù)據(jù)一起存儲在一個數(shù)據(jù)結(jié)構(gòu)中,然后使用一個通用的函數(shù)或方法來處理這個數(shù)據(jù)結(jié)構(gòu)。這種方法可以將大量的if else語句轉(zhuǎn)換為數(shù)據(jù)結(jié)構(gòu)的處理過程,從而提高代碼的可擴展性和可維護性。
示例:
import java.util.ArrayList;
import java.util.List;
import java.util.function.Function;
public class DataDrivenDesignExample {
private List<Function<Integer, Integer>> functionList;
public DataDrivenDesignExample() {
functionList = new ArrayList<>();
functionList.add(x -> x + 1);
functionList.add(x -> x - 1);
functionList.add(x -> x * 2);
functionList.add(x -> x / 2);
}
public int calculate(int operationIndex, int input) {
if (operationIndex < 0 || operationIndex >= functionList.size()) {
throw new IllegalArgumentException("Invalid operation index: " + operationIndex);
}
return functionList.get(operationIndex).apply(input);
}
public static void main(String[] args) {
DataDrivenDesignExample example = new DataDrivenDesignExample();
System.out.println(example.calculate(0, 10));
System.out.println(example.calculate(1, 10));
System.out.println(example.calculate(2, 10));
System.out.println(example.calculate(3, 10));
System.out.println(example.calculate(4, 10)); // 拋出異常
}
}總結(jié)
到此這篇關(guān)于java中優(yōu)化大量if...else...的文章就介紹到這了,更多相關(guān)java優(yōu)化大量if...else...內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
淺談基于SpringBoot實現(xiàn)一個簡單的權(quán)限控制注解
這篇文章主要介紹了基于SpringBoot實現(xiàn)一個簡單的權(quán)限控制注解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2021-01-01
Spring Boot2.x集成JPA快速開發(fā)的示例代碼
這篇文章主要介紹了Spring Boot2.x集成JPA快速開發(fā),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-05-05
SpringBoot結(jié)合WebSocket實現(xiàn)聊天功能
本文介紹了如何使用SpringBoot和WebSocket實現(xiàn)一個簡單的聊天功能,包括導入依賴、配置類、創(chuàng)建消息實體、指定ServerEndpoint、創(chuàng)建客戶端等步驟,通過具體示例,演示了如何發(fā)送個人消息和群發(fā)消息,實現(xiàn)了基本的聊天功能,適合需要在項目中實現(xiàn)實時通訊功能的開發(fā)者參考2024-11-11
Java中synchronized?的4個優(yōu)化技巧
本文主要介紹了Java中synchronized的4個優(yōu)化技巧,synchronized在JDK?1.5?時性能是比較低的,然而在后續(xù)的版本中經(jīng)過各種優(yōu)化迭代,它的性能也得到了前所未有的提升,下文更多相關(guān)資料需要的小伙伴可以參考一下2022-05-05
spring boot加載freemarker模板路徑的方法
這篇文章主要介紹了spring boot加載freemarker模板路徑的方法,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-11-11

