Heim  >  Artikel  >  Java  >  Einführung in Beispiele für die if-Verarbeitung von Strukturen mit mehreren Zweigen und die Mängel zu langer if-Anweisungen

Einführung in Beispiele für die if-Verarbeitung von Strukturen mit mehreren Zweigen und die Mängel zu langer if-Anweisungen

巴扎黑
巴扎黑Original
2017-07-18 15:17:053404Durchsuche

Beispiel 1

import java.util.Scanner;/**
 * Created by liwenj on 2017/7/17. */public class test7 {public static void main(String[] args) {
        Scanner input=new Scanner(System.in);int money=input.nextInt();if(money>500){
            System.out.println("我要买一个凯迪拉克");
        }else if(money>100){
            System.out.println("我要买一个帕萨特");
        }else if(money>50){
            System.out.println("我要买一个伊兰特");
        }else if(money>10){
            System.out.println("我要买一个奥拓");
        }else{
            System.out.println("我要买一个拖拉机");
        }
    }
}

Beispiel 2

import java.util.Scanner;/**
 * Created by liwenj on 2017/7/17. */public class test8 {public static void main(String[] args) {
        Scanner input = new Scanner(System.in);
        System.out.println("请输入是否是会员");
        String huiyuan = input.next();boolean f = huiyuan.equals("yes");
        System.out.println("请输入消费金额");double money = input.nextDouble();if (f) {if (money >= 200) {double dazhe = money * 0.75;
                System.out.println("你消费:" + dazhe);
            } else {double dazhe = money * 0.8;
                System.out.println("你消费:" + dazhe);
            }

        } else if (money >= 100) {double dazhe = money * 0.9;
            System.out.println("你消费:" + dazhe);
        }else{
            System.out.println("你消费:"+money);
        }

    }

}

Übermäßig lange Strukturen mit mehreren Zweigen sind Oft wird es als unerwünschte Struktur in Software angesehen, da es gegen das OCP-Prinzip (offenes und geschlossenes Prinzip) verstößt. Immer wenn eine neue bedingte Beurteilungsverarbeitung hinzugefügt werden muss, muss ein if-else-Zweig hinzugefügt werden.

In vielen Fällen ist die Verwendung einer Funktionstabellenstruktur eine wirksame Möglichkeit, zu lange Verzweigungsstrukturen zu vermeiden. Im Folgenden finden Sie einen Lösungsalgorithmus für das Problem „Wolf, Schaf und Gemüse überqueren den Fluss“ mithilfe einer Funktionstabellenstruktur anstelle einer zu langen Zweigstruktur. Beispiel einer Struktur mit mehreren Zweigen. Der Landwirt kann insgesamt 8 Aktionen ausführen, und jede Aktion entspricht einem Zustandsübergangsverarbeitungsprozess. Wenn eine if-else-Struktur mit mehreren Zweigen verwendet wird, ist der Code für die Verarbeitung von Zustandsübergängen sehr lang. Um übermäßig lange Sprungcodes für Verzweigungen zu vermeiden, verwendet der Algorithmus eine Funktionstabellenstruktur. Deklarieren Sie zunächst die Definition des Funktionstabellenelements:

print?
typedef bool (*ProcessFuncPtr)(const ItemState& current, ItemState& next);  
struct ActionProcess{  
    Action act;  
    ProcessNextFuncPtr processFunc;  
}


Das obige ist der detaillierte Inhalt vonEinführung in Beispiele für die if-Verarbeitung von Strukturen mit mehreren Zweigen und die Mängel zu langer if-Anweisungen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn