Heim Backend-Entwicklung C#.Net-Tutorial Vertieftes Verständnis des Strategiemusters von C#-Entwurfsmustern und rollenspezifisches Case-Sharing

Vertieftes Verständnis des Strategiemusters von C#-Entwurfsmustern und rollenspezifisches Case-Sharing

Jul 28, 2018 am 11:57 AM
c# 设计模式

Strategiemuster

Strategiemuster ist ein Verhaltensmuster, das eine Reihe von Algorithmen definiert, jeden Algorithmus kapselt und sie austauschbar macht, sodass sich der Algorithmus ändern kann unabhängig vom Client, der es verwendet.

Durch die Verwendung des Strategiemusters können Verhalten und Umgebung getrennt werden. Die Umgebungsklasse ist für die Verwaltung und Abfrage der Verhaltensklasse verantwortlich, und in der spezifischen Strategieklasse werden verschiedene Algorithmen bereitgestellt.

Rolle:

1. Abstrakte Strategie (Strategie)

Dies ist eine abstrakte Rolle, die normalerweise durch eine Schnittstelle oder eine abstrakte Klasse implementiert wird. Diese Rolle stellt alle Schnittstellen bereit, die für konkrete Strategieklassen erforderlich sind.

Eine konkrete Strategieklasse, die abstrakte Strategien implementiert und verwandte Algorithmen oder Verhaltensweisen implementiert . Umgebungsklasse (Kontext)

enthält einen Verweis auf die Strategieklasse und kann die entsprechende Strategie für die Instanz basierend auf der Logik auswählen.

Beispiel:

Der Namespace StrategyPattern enthält die Strategie-Basisklasse Tax und ihre 8 Implementierungsklassen, die There unterstützen sind Strategie-Basisklassen. Dieses Beispiel bietet eine elegante Möglichkeit, die Einkommensteuer zu berechnen.

Vertieftes Verständnis des Strategiemusters von C#-Entwurfsmustern und rollenspezifisches Case-SharingC#-Entwicklungsnotizen 04 – Wie kann man mit C# die persönliche Einkommensteuer elegant berechnen?

namespace StragetyPattern
Nach dem Login kopieren
rrree

Die Strategie-Basisklasse Tax stellt die persönliche Einkommensteuer dar, TaxRate ist der Steuersatz, QuickDeduction ist der Schnellberechnungsabzug und Calculate berechnet die persönliche Einkommensteuer des entsprechenden Einkommens.

public abstract class Tax {

    protected decimal TaxRate = 0;

    protected decimal QuickDeduction = 0;

    public virtual decimal Calculate(decimal income) {
        return income * TaxRate - QuickDeduction;
    }

}
Nach dem Login kopieren

Stufe 0 der Einkommensteuerleiter stellt den Ausgangsstatus der Einkommensteuer dar.

public class Level0 : Tax {

    public Level0() {
        TaxRate = 0.00m;
        QuickDeduction = 0;
    }

}
Nach dem Login kopieren

Einkommensteuerleiter der Stufe 1.

public class Level1 : Tax {

    public Level1() {
        TaxRate = 0.03m;
        QuickDeduction = 0;
    }

}
Nach dem Login kopieren

Einkommensteuerleiter der Stufe 2.

public class Level2 : Tax {

    public Level2() {
        TaxRate = 0.10m;
        QuickDeduction = 105;
    }

}
Nach dem Login kopieren

3 Stufen der persönlichen Einkommensteuerleiter.

public class Level3 : Tax {

    public Level3() {
        TaxRate = 0.20m;
        QuickDeduction = 555;
    }

}
Nach dem Login kopieren

4 Stufen der persönlichen Einkommensteuerleiter.

public class Level4 : Tax {

    public Level4() {
        TaxRate = 0.25m;
        QuickDeduction = 1005;
    }

}
Nach dem Login kopieren

5 Stufen der persönlichen Einkommensteuerleiter.

public class Level5 : Tax {

    public Level5() {
        TaxRate = 0.30m;
        QuickDeduction = 2755;
    }

}
Nach dem Login kopieren

6 Stufen der persönlichen Einkommensteuerleiter.

public class Level6 : Tax {

    public Level6() {
        TaxRate = 0.35m;
        QuickDeduction = 5505;
    }

}
Nach dem Login kopieren

7 Stufen der persönlichen Einkommensteuerleiter.

public class Level7 : Tax {

    public Level7() {
        TaxRate = 0.45m;
        QuickDeduction = 13505;
    }

}
Nach dem Login kopieren

Umgebungsklasse Kontext: Zuerst muss ein Verweis auf Steuern gepflegt werden, EXEMPTION_VALUE stellt den Befreiungsbetrag dar (in diesem Beispiel werden 3500 Yuan verwendet) und dann die entsprechende Steuerimplementierungsklasse durch Reflexion und einige zu berechnende Techniken auswählen die Personen der entsprechenden Leiter Einkommensteuer.

public class Context {

    private Tax _tax = null;

    private const decimal EXEMPTION_VALUE = 3500m;

    private List<decimal> _taxLevel = new List<decimal>{
        0,
        1500,
        4500,
        9000,
        35000,
        55000,
        80000,
        decimal.MaxValue
    };

    private List<Type> _levels = new List<Type>();

    private void GetLevels() {
        _levels = AppDomain.CurrentDomain.GetAssemblies()
                           .SelectMany(tp => tp.GetTypes()
                           .Where(t => t.BaseType == typeof(Tax)))
                           .ToList();
    }

    public Context() {
        GetLevels();
    }

    public Context Calculate(decimal income) {
        _tax = new Level0();
        var result = income - EXEMPTION_VALUE;
        for(int i = 1; i <= _taxLevel.Count - 1; i++) {
            if(result > _taxLevel[i - 1] && result <= _taxLevel[i]) {
                _tax = (Tax)Activator.CreateInstance(_levels[i]);
            }
        }
        Console.WriteLine($"Income = {income}," + $"tax = {_tax.Calculate(result)}!");
        return this;
    }

}
Nach dem Login kopieren

Das Obige ist der Code des Aufrufers. Calculate wird speziell verarbeitet, um die Methodenverkettung zu unterstützen. Das Folgende ist das Ausgabeergebnis dieses Falls:

public class Program {

    private static Context _context = new Context();

    public static void Main(string[] args) {
        _context.Calculate(2500.00m)
                .Calculate(4900.00m)
                .Calculate(5500.00m)
                .Calculate(7000.00m)
                .Calculate(10000.00m)
                .Calculate(16000.00m)
                .Calculate(43000.00m)
                .Calculate(70000.00m)
                .Calculate(100000.00m)
                .Calculate(4500.00m)
                .Calculate(1986.00m);

        Console.ReadKey();
    }

}
Nach dem Login kopieren

Vorteile:

1 Die hierarchische Struktur der Strategieklasse definiert die ordnungsgemäße Verwendung von Vererbung kann öffentliche Codes in die übergeordnete Klasse verschieben, um doppelten Code zu vermeiden 2. Vererbung kann eine Vielzahl von Algorithmen oder Verhaltensweisen verarbeiten und die Verwendung mehrerer bedingter Übertragungsanweisungen vermeiden.

Nachteile:

1. Der Kunde muss alle Versicherungsklassen kennen und entscheiden, welche er verwenden möchte. 2 Strategieklasse, die eine „Unterklassenexplosion“ verursacht.

Nutzungsszenarien:

1. Wenn es in einem System viele Klassen gibt und der einzige Unterschied zwischen ihnen im Verhalten liegt, dann kann das Strategiemuster dynamisch genutzt werden Lassen Sie ein Objekt ein Verhalten unter vielen Verhaltensweisen auswählen. 2. Ein System muss dynamisch einen von mehreren Algorithmen auswählen. Verwandte Artikel:


PHP-Erweiterung mit C/C++ schreiben

[c#-Tutorial] C#-Datentypen

Ähnliche Videos:

Was ist ein Designmuster? - PHP-Video-Tutorial zu erweiterten Designmustern

Das obige ist der detaillierte Inhalt vonVertieftes Verständnis des Strategiemusters von C#-Entwurfsmustern und rollenspezifisches Case-Sharing. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
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

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Active Directory mit C# Active Directory mit C# Sep 03, 2024 pm 03:33 PM

Leitfaden zu Active Directory mit C#. Hier besprechen wir die Einführung und die Funktionsweise von Active Directory in C# sowie die Syntax und das Beispiel.

C#-Serialisierung C#-Serialisierung Sep 03, 2024 pm 03:30 PM

Leitfaden zur C#-Serialisierung. Hier besprechen wir die Einführung, die Schritte des C#-Serialisierungsobjekts, die Funktionsweise bzw. das Beispiel.

Zufallszahlengenerator in C# Zufallszahlengenerator in C# Sep 03, 2024 pm 03:34 PM

Leitfaden zum Zufallszahlengenerator in C#. Hier besprechen wir die Funktionsweise des Zufallszahlengenerators, das Konzept von Pseudozufallszahlen und sicheren Zahlen.

C#-Datenrasteransicht C#-Datenrasteransicht Sep 03, 2024 pm 03:32 PM

Leitfaden zur C#-Datenrasteransicht. Hier diskutieren wir die Beispiele, wie eine Datenrasteransicht aus der SQL-Datenbank oder einer Excel-Datei geladen und exportiert werden kann.

Muster in C# Muster in C# Sep 03, 2024 pm 03:33 PM

Leitfaden zu Mustern in C#. Hier besprechen wir die Einführung und die drei wichtigsten Arten von Mustern in C# zusammen mit ihren Beispielen und der Code-Implementierung.

Primzahlen in C# Primzahlen in C# Sep 03, 2024 pm 03:35 PM

Leitfaden zu Primzahlen in C#. Hier besprechen wir die Einführung und Beispiele von Primzahlen in C# sowie die Codeimplementierung.

Fakultät in C# Fakultät in C# Sep 03, 2024 pm 03:34 PM

Leitfaden zur Fakultät in C#. Hier diskutieren wir die Einführung in die Fakultät in C# zusammen mit verschiedenen Beispielen und Code-Implementierungen.

Der Unterschied zwischen Multithreading und asynchronem C# Der Unterschied zwischen Multithreading und asynchronem C# Apr 03, 2025 pm 02:57 PM

Der Unterschied zwischen Multithreading und Asynchron besteht darin, dass Multithreading gleichzeitig mehrere Threads ausführt, während asynchron Operationen ausführt, ohne den aktuellen Thread zu blockieren. Multithreading wird für rechenintensive Aufgaben verwendet, während asynchron für die Benutzerinteraktion verwendet wird. Der Vorteil des Multi-Threading besteht darin, die Rechenleistung zu verbessern, während der Vorteil von Asynchron nicht darin besteht, UI-Threads zu blockieren. Die Auswahl von Multithreading oder Asynchron ist von der Art der Aufgabe abhängt: Berechnungsintensive Aufgaben verwenden Multithreading, Aufgaben, die mit externen Ressourcen interagieren und die UI-Reaktionsfähigkeit asynchron verwenden müssen.

See all articles