Table des matières
1. switch
Quand il s'agit de logiques de traitement plus complexes, nous préférons séparer ces logiques de traitement séparément, plutôt que de continuer à les traiter en une seule méthode, pour augmenter la lisibilité globale et le découplage. C'est également le modèle que nous avons dérivé de l'utilisation d'interfaces fonctionnelles pour. processus if else. L'essence du traitement de la carte d'interface fonctionnelle if else est d'extraire la logique de traitement complexe de chaque condition dans une méthode d'interface fonctionnelle et d'utiliser des conditions de jugement unifiées. Pour appeler différentes méthodes, les exemples spécifiques sont les suivants
La forme du modèle de stratégie est adaptée à la mise en œuvre de méthodes plus complexes. Les situations nécessitent un scénario plus propre où la logique de traitement est découplée
Maison Java javaDidacticiel Comment écrire if-else avec élégance en Java

Comment écrire if-else avec élégance en Java

Apr 29, 2023 pm 10:04 PM
java if-else

1. switch

La méthode switch a de bons effets sur le traitement des valeurs d'énumération. Par exemple, différents traitements doivent être effectués pour différents statuts de commande, car les valeurs de statut sont limitées pour le moment. effectuez un traitement différent pour différents statuts Traitement :

Déclaration originale

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("订单已签收");
        }
    }
Copier après la connexion

switch

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("订单已签收");
        }
    }
Copier après la connexion

Résumé : 

L'instruction switch convient aux scénarios où les conditions de jugement sont limitées et aucun calcul complexe n'est requis, et l'instruction de traitement est simple. Si nos conditions de jugement nécessitent une série de calculs complexes, ou si la logique des instructions de traitement est relativement complexe, nous devons envisager d'autres méthodes de traitement. Après tout, écrire beaucoup d'instructions de traitement dans le cas n'est pas pratique. interface

Quand il s'agit de logiques de traitement plus complexes, nous préférons séparer ces logiques de traitement séparément, plutôt que de continuer à les traiter en une seule méthode, pour augmenter la lisibilité globale et le découplage. C'est également le modèle que nous avons dérivé de l'utilisation d'interfaces fonctionnelles pour. processus if else. L'essence du traitement de la carte d'interface fonctionnelle if else est d'extraire la logique de traitement complexe de chaque condition dans une méthode d'interface fonctionnelle et d'utiliser des conditions de jugement unifiées. Pour appeler différentes méthodes, les exemples spécifiques sont les suivants

@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;
    }

}
Copier après la connexion

Lors de l'appel , il n'est pas nécessaire d'utiliser if else pour distinguer. Transmettez directement les paramètres à la fonction map pour appeler

   @Autowired
    private FunctionInterfaceStrategy functionInterfaceStrategy;
    
    
    functionInterfaceStrategy.doOperation("参数",1);
Copier après la connexion

Bien sûr, ce que nous avons démontré ci-dessus est une interface fonctionnelle avec des paramètres et des valeurs de retour, en production réelle, nous pouvons. Nous avons également besoin d'autres formes d'interfaces fonctionnelles, nous les répertorions séparément pour votre référence

Nom de l'interfaceDescriptionAucun paramètre, avec valeur de retourAvec paramètres, aucune valeur de retourAucun paramètre, aucune valeur de retourIl y a des paramètres et renvoie une valeur 3. Modèle de stratégie Le formulaire d'interface fonctionnelle mentionné ci-dessus sépare en fait les méthodes.Toutes les méthodes d'implémentation sont toujours placées dans une seule classe, même si vous pouvez l'utiliser dans la classe FunctionInterfaceStrategy. Les méthodes d'autres classes sont à nouveau appelées via l'injection de dépendances, mais ce modèle On se rapproche déjà de la prochaine méthode que nous allons utiliser, qui consiste à utiliser le modèle de stratégie pour résoudre si autrement
Méthode d'appelFournisseur
getConsommateur
accepterRunnable
runFonction
apply

La forme du modèle de stratégie est adaptée à la mise en œuvre de méthodes plus complexes. Les situations nécessitent un scénario plus propre où la logique de traitement est découplée

1. Tout d'abord, nous devons créer une classe d'interface pour spécifier le format de nos classes d'implémentation ultérieures

public interface OrderStrategy {

    /**
     * 获取实现类标识
     * @return
     */
    Integer getType();

    /**
     * 逻辑处理
     * @param params
     * @return
     */
    Boolean handler(Object params);

}
Copier après la connexion

2. Deuxièmement, créer une classe d'interface pour chaque condition de jugement Classe d'implémentation

@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;
    }
}
Copier après la connexion

3 Créer une classe d'usine de stratégie à héberger. la classe d'implémentation

@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);
    }

}
Copier après la connexion

4. Appel de méthode

@RestController
@RequestMapping("ifelse")
@AllArgsConstructor
public class IfElseController {

    private final OrderStrategyFactory orderStrategyFactory;

    @GetMapping("strategy")
    public Boolean strategy(Integer status){
        return orderStrategyFactory.handler(status,"1");
    }

}
Copier après la connexion

Résumé :

Grâce aux exemples de code ci-dessus, vous pouvez réellement constater que les interfaces fonctionnelles et les modèles de stratégie ont le même objectif. La différence fondamentale est de savoir si la méthode d'implémentation doit être extraite. séparément dans une classe d’implémentation. Plus la granularité de l'extraction est fine, plus le découplage est fort. Si vous devez ajouter des conditions if else plus tard, il vous suffit d'ajouter la classe d'implémentation. Ce sera plus pratique pour le traitement ultérieur. en fin de compte, cela reste à déterminer. Cela dépend de la situation commerciale spécifique

4. Déclaration de garde

Nous devons souvent traiter diverses logiques de jugement d'imbrication de paramètres avant la méthode. Si les conditions ne sont pas remplies, elle sera renvoyée directement. Dans ce cas, il est plus recommandé d'utiliser des déclarations de garde

Phrase originale

    public void before(Integer status) {
        if(status != null) {
            if(status != 0){
                if(status == 1){
                    System.out.println("订单未接单");
                }
            }
        }
    }
Copier après la connexion

Phrase Wei

    public void greater(Integer status) {
        if(status == null){
            return;
        }
        if(status != 0){
            return;
        }
        if(status == 1){
            System.out.println("订单未接单");
        }
    }
Copier après la connexion
.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Commandes de chat et comment les utiliser
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Nombre parfait en Java Nombre parfait en Java Aug 30, 2024 pm 04:28 PM

Guide du nombre parfait en Java. Nous discutons ici de la définition, comment vérifier le nombre parfait en Java ?, des exemples d'implémentation de code.

Générateur de nombres aléatoires en Java Générateur de nombres aléatoires en Java Aug 30, 2024 pm 04:27 PM

Guide du générateur de nombres aléatoires en Java. Nous discutons ici des fonctions en Java avec des exemples et de deux générateurs différents avec d'autres exemples.

Weka en Java Weka en Java Aug 30, 2024 pm 04:28 PM

Guide de Weka en Java. Nous discutons ici de l'introduction, de la façon d'utiliser Weka Java, du type de plate-forme et des avantages avec des exemples.

Numéro de Smith en Java Numéro de Smith en Java Aug 30, 2024 pm 04:28 PM

Guide du nombre de Smith en Java. Nous discutons ici de la définition, comment vérifier le numéro Smith en Java ? exemple avec implémentation de code.

Questions d'entretien chez Java Spring Questions d'entretien chez Java Spring Aug 30, 2024 pm 04:29 PM

Dans cet article, nous avons conservé les questions d'entretien Java Spring les plus posées avec leurs réponses détaillées. Pour que vous puissiez réussir l'interview.

Break or Return of Java 8 Stream Forach? Break or Return of Java 8 Stream Forach? Feb 07, 2025 pm 12:09 PM

Java 8 présente l'API Stream, fournissant un moyen puissant et expressif de traiter les collections de données. Cependant, une question courante lors de l'utilisation du flux est: comment se casser ou revenir d'une opération FOREAK? Les boucles traditionnelles permettent une interruption ou un retour précoce, mais la méthode Foreach de Stream ne prend pas directement en charge cette méthode. Cet article expliquera les raisons et explorera des méthodes alternatives pour la mise en œuvre de terminaison prématurée dans les systèmes de traitement de flux. Lire plus approfondie: Améliorations de l'API Java Stream Comprendre le flux Forach La méthode foreach est une opération terminale qui effectue une opération sur chaque élément du flux. Son intention de conception est

Horodatage à ce jour en Java Horodatage à ce jour en Java Aug 30, 2024 pm 04:28 PM

Guide de TimeStamp to Date en Java. Ici, nous discutons également de l'introduction et de la façon de convertir l'horodatage en date en Java avec des exemples.

Programme Java pour trouver le volume de la capsule Programme Java pour trouver le volume de la capsule Feb 07, 2025 am 11:37 AM

Les capsules sont des figures géométriques tridimensionnelles, composées d'un cylindre et d'un hémisphère aux deux extrémités. Le volume de la capsule peut être calculé en ajoutant le volume du cylindre et le volume de l'hémisphère aux deux extrémités. Ce tutoriel discutera de la façon de calculer le volume d'une capsule donnée en Java en utilisant différentes méthodes. Formule de volume de capsule La formule du volume de la capsule est la suivante: Volume de capsule = volume cylindrique volume de deux hémisphères volume dans, R: Le rayon de l'hémisphère. H: La hauteur du cylindre (à l'exclusion de l'hémisphère). Exemple 1 entrer Rayon = 5 unités Hauteur = 10 unités Sortir Volume = 1570,8 unités cubes expliquer Calculer le volume à l'aide de la formule: Volume = π × r2 × h (4

See all articles