Bagaimana untuk menulis if-else secara elegan di Jawa
1. suis
Kaedah suis mempunyai kesan yang baik pada pemprosesan nilai penghitungan Sebagai contoh, pemprosesan yang berbeza perlu dilakukan untuk status pesanan yang berbeza, kerana nilai status adalah terhad, maka kita boleh menggunakan beralih terus. Untuk melakukan pemprosesan yang berbeza untuk keadaan yang berbeza:
Pernyataan asal
public void before(Integer status) { if(status == 1){ System.out.println("订单未接单"); }else if(status == 2){ System.out.println("订单未发货"); }else if(status == 3){ System.out.println("订单未签收"); }else{ System.out.println("订单已签收"); } }
suis
public void greater(Integer status) { switch (status){ case 1: System.out.println("订单未接单"); break; case 2: System.out.println("订单未发货"); break; case 3: System.out.println("订单未签收"); break; default: System.out.println("订单已签收"); } }
Ringkasan:
penyataan suis sesuai untuk keadaan penghakiman terhad dan tidak perlu Selepas pengiraan yang rumit, kendalikan senario dengan pernyataan mudah. Jika syarat penghakiman kami memerlukan satu siri pengiraan yang rumit, atau logik penyata pemprosesan agak rumit, kami perlu mempertimbangkan kaedah pemprosesan lain Lagipun, menulis banyak kenyataan pemprosesan dalam kes itu tidak selesa >2. Antara muka berfungsi
Apabila berurusan dengan logik pemprosesan yang lebih kompleks, kami lebih suka memisahkan logik pemprosesan ini secara berasingan, daripada masih memprosesnya dalam satu kaedah, sambil menambah Kebolehbacaan dan penyahgandingan keseluruhan juga merupakan sebab kami memperoleh corak menggunakan antara muka berfungsi untuk mengendalikan if else
Intipati peta antara muka berfungsi untuk mengendalikan if else adalah untuk mengekstrak logik pemprosesan yang kompleks bagi setiap keadaan secara berasingan syarat penghakiman. Contoh khusus adalah seperti berikut
@Component public class FunctionInterfaceStrategy { /** * key 方法参数,多个参数可以自定义一个实体类处理 * value 方法返回值 */ private Map<Integer, Function<Object,Boolean>> operationMap; @PostConstruct private void init(){ operationMap = new HashMap<>(); operationMap.put(1,this::takeOrder); operationMap.put(2,this::sendOrder); operationMap.put(3,this::signOrder); operationMap.put(4,this::finishOrder); } public Boolean doOperation(Object params,Integer status){ return operationMap.get(status) == null || operationMap.get(status).apply(params); } private Boolean takeOrder(Object params){ // TODO 比较复杂的处理逻辑 System.out.println("订单未接单"); return true; } private Boolean sendOrder(Object params){ // TODO 比较复杂的处理逻辑 System.out.println("订单未发货"); return true; } private Boolean signOrder(Object params){ // TODO 比较复杂的处理逻辑 System.out.println("订单未签收"); return true; } private Boolean finishOrder(Object params){ // TODO 比较复杂的处理逻辑 System.out.println("订单已签收"); return true; } }
Apabila memanggil, anda tidak perlu menggunakan if else untuk membezakan secara terus parameter dan memanggilnya dalam peta fungsi
@Autowired private FunctionInterfaceStrategy functionInterfaceStrategy; functionInterfaceStrategy.doOperation("参数",1);
. Sudah tentu, apa yang kami tunjukkan di atas ialah antara muka berfungsi dengan parameter dan nilai pulangan Dalam pengeluaran sebenar, kami mungkin juga memerlukan bentuk antara muka berfungsi yang lain untuk rujukan anda
3 corak接口名称 | 说明 | 调用方法 |
---|---|---|
Supplier | 无参数,有返回值 | get |
Consumer | 有参数,无返回值 | accept |
Runnable | 无参数,无返回值 | run |
Function | 有参数,有返回值 | apply |
Borang antara muka berfungsi yang dinyatakan di atas sebenarnya memisahkan kaedah Semua kaedah pelaksanaan masih diletakkan dalam satu kelas, walaupun anda boleh menggunakannya dalam kelas FunctionInterfaceStrategy Kaedah kelas lain dipanggil semula melalui suntikan kebergantungan. tetapi corak ini sudah menghampiri kaedah seterusnya yang akan kami gunakan, iaitu menggunakan corak strategi untuk menyelesaikan corak strategi if else
Untuk situasi yang kaedah pelaksanaannya lebih kompleks, senario yang lebih bersih yang mana logik pemprosesan perlu dipisahkan
1 Pertama, kita perlu mencipta kelas antara muka untuk menentukan format kelas pelaksanaan seterusnya
public interface OrderStrategy { /** * 获取实现类标识 * @return */ Integer getType(); /** * 逻辑处理 * @param params * @return */ Boolean handler(Object params); }
2 🎜>
@Service public class SendOrderStrategy implements OrderStrategy{ @Override public Integer getType() { return 2; } @Override public Boolean handler(Object params) { // TODO 复杂的处理逻辑 System.out.println("订单未发货"); return true; } } @Service public class SignOrderStrategy implements OrderStrategy{ @Override public Integer getType() { return 3; } @Override public Boolean handler(Object params) { // TODO 复杂的处理逻辑 System.out.println("订单未签收"); return true; } } @Service public class TakeOrderStrategy implements OrderStrategy{ @Override public Integer getType() { return 1; } @Override public Boolean handler(Object params) { // TODO 复杂的处理逻辑 System.out.println("订单未接单"); return true; } }
@Component @AllArgsConstructor public class OrderStrategyFactory { private final List<OrderStrategy> orderStrategyList; private static Map<Integer,OrderStrategy> strategyMap = new HashMap<>(); @PostConstruct private void init(){ for (OrderStrategy orderStrategy : orderStrategyList) { strategyMap.put(orderStrategy.getType(),orderStrategy); } } /** * 执行方法 * @param status * @param params * @return */ public Boolean handler(Integer status,Object params){ return strategyMap.get(status).handler(params); } }
@RestController @RequestMapping("ifelse") @AllArgsConstructor public class IfElseController { private final OrderStrategyFactory orderStrategyFactory; @GetMapping("strategy") public Boolean strategy(Integer status){ return orderStrategyFactory.handler(status,"1"); } }
Yang mana satu untuk digunakan akhirnya bergantung pada situasi perniagaan tertentu
4 Penyataan pengawal
Kita selalunya perlu memproses pelbagai parameter bersarang logik pertimbangan sebelum kaedah tersebut tidak dipenuhi, Ia dikembalikan secara langsung Dalam kes ini, lebih disyorkan untuk menggunakan pernyataan pengawal untuk memproses
kenyataan asal
public void before(Integer status) { if(status != null) { if(status != 0){ if(status == 1){ System.out.println("订单未接单"); } } } }
kenyataan pengawal
public void greater(Integer status) { if(status == null){ return; } if(status != 0){ return; } if(status == 1){ System.out.println("订单未接单"); } }
Atas ialah kandungan terperinci Bagaimana untuk menulis if-else secara elegan di Jawa. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas

Panduan untuk Square Root di Java. Di sini kita membincangkan cara Square Root berfungsi di Java dengan contoh dan pelaksanaan kodnya masing-masing.

Panduan Nombor Sempurna di Jawa. Di sini kita membincangkan Definisi, Bagaimana untuk menyemak nombor Perfect dalam Java?, contoh dengan pelaksanaan kod.

Panduan untuk Penjana Nombor Rawak di Jawa. Di sini kita membincangkan Fungsi dalam Java dengan contoh dan dua Penjana berbeza dengan contoh lain.

Panduan untuk Weka di Jawa. Di sini kita membincangkan Pengenalan, cara menggunakan weka java, jenis platform, dan kelebihan dengan contoh.

Panduan untuk Nombor Armstrong di Jawa. Di sini kita membincangkan pengenalan kepada nombor Armstrong di java bersama-sama dengan beberapa kod.

Panduan untuk Nombor Smith di Jawa. Di sini kita membincangkan Definisi, Bagaimana untuk menyemak nombor smith di Jawa? contoh dengan pelaksanaan kod.

Dalam artikel ini, kami telah menyimpan Soalan Temuduga Spring Java yang paling banyak ditanya dengan jawapan terperinci mereka. Supaya anda boleh memecahkan temuduga.

Java 8 memperkenalkan API Stream, menyediakan cara yang kuat dan ekspresif untuk memproses koleksi data. Walau bagaimanapun, soalan biasa apabila menggunakan aliran adalah: bagaimana untuk memecahkan atau kembali dari operasi foreach? Gelung tradisional membolehkan gangguan awal atau pulangan, tetapi kaedah Foreach Stream tidak menyokong secara langsung kaedah ini. Artikel ini akan menerangkan sebab -sebab dan meneroka kaedah alternatif untuk melaksanakan penamatan pramatang dalam sistem pemprosesan aliran. Bacaan Lanjut: Penambahbaikan API Java Stream Memahami aliran aliran Kaedah Foreach adalah operasi terminal yang melakukan satu operasi pada setiap elemen dalam aliran. Niat reka bentuknya adalah
