Single Responsibility Principle(SRP)
Dieses Prinzip besagt, dass jede Klasse eine einzige Verantwortung haben sollte. Es betont, dass eine Klasse eine bestimmte Funktion ausführen sollte und nicht zu viele Gründe für eine Änderung haben sollte.
Beispiel: Benutzerinformationen verwalten und E-Mail-Benachrichtigungen senden.
class UserManager:
def create_user(self, user_data):
# Logic for creating a user
pass
class EmailService:
def send_email(self, email_data):
# Logic for sending an email
pass
Open/Closed Principle(OCP)
Dieses Prinzip fördert die Erweiterung der Funktionalität durch das Hinzufügen von neuem Code, anstatt vorhandenen Code zu ändern.
Beispiel: Umgang mit verschiedenen Zahlungsmethoden in einer E-Commerce-Anwendung.
from abc import ABC, abstractmethod
class PaymentProcessor(ABC):
@abstractmethod
def process_payment(self):
pass
class CreditCardPaymentProcessor(PaymentProcessor):
def process_payment(self):
# Logic for processing credit card payment
pass
class PayPalPaymentProcessor(PaymentProcessor):
def process_payment(self):
# Logic for processing PayPal payment
pass
Liskov Substitution Principle(LSP)
Dieses Prinzip besagt, dass Objekte einer abgeleiteten Klasse durch Objekte der Basisklasse ersetzt werden sollten, ohne die Korrektheit des Programms zu beeinträchtigen.
Beispiel: Geometrische Formen verwalten.
class Shape:
def area(self):
pass
class Rectangle(Shape):
def area(self):
return self.width * self.height
class Square(Shape):
def area(self):
return self.side * self.side
Interface Segregation Principle(ISP)
Dieses Prinzip empfiehlt, Schnittstellen in kleinere aufzuteilen, um zu vermeiden, dass Klassen gezwungen werden, Methoden zu implementieren, die sie nicht benötigen.
Beispiel: Schnittstellen zur Aktualisierung und Anzeige von Daten.
class UpdateableFeature:
@abstractmethod
def update_feature(self):
pass
class DisplayableFeature:
@abstractmethod
def display_feature(self):
pass
Dependency Inversion Principle(DIP)
Dieses Prinzip schlägt vor, Abhängigkeitsinjektion zur Verwaltung von Abhängigkeiten zu verwenden.
Beispiel: Abhängigkeitsinjektion zum Verwalten von Abhängigkeiten verwenden.
class OrderProcessor:
def __init__(self, db_connection, email_service):
self.db_connection = db_connection
self.email_service = email_service
Denken Sie daran, dass die Anwendung SOLID der Prinzipien Python flexibel und auf der Grundlage des spezifischen Zwecks Ihres Projekts und Ihres Verständnisses von SOLID und erfolgen sollte Python.