Démarrez avec PHP : modèles de stratégie
Dans tout langage de programmation, les modèles de conception font partie intégrante du développement. Le modèle Strategy en fait partie, qui condense le code réutilisable et implémente mieux le principe ouvert-fermé. Cet article présentera le concept de Strategy Pattern et comment l'implémenter en PHP.
Qu'est-ce que le mode stratégie ?
Le modèle de stratégie consiste à définir une série d'algorithmes, à les encapsuler et à les rendre interchangeables. Il permet de modifier l'utilisation d'un algorithme sans avoir à refactoriser le code dans le code qui appelle l'algorithme.
En termes simples, le modèle de stratégie peut vous donner un moyen de changer d'algorithme en fonction des besoins pendant l'exécution, et il vous permet également d'étendre l'algorithme en héritant de classes spécifiques.
Vous trouverez ci-dessous un exemple très simple qui démontrera comment utiliser le mode Stratégie pour choisir différentes manières de calculer le bonus de fin d'année. Supposons que nous ayons une classe d'employés qui doit calculer les primes de fin d'année pour les employés de différents niveaux. Dans ce cas, le modèle Strategy nous permet d'implémenter certains algorithmes.
/**
employé de classe
{
private $salary; private $strategy; public function __construct($salary, BonusStrategy $strategy) { $this->salary = $salary; $this->strategy = $strategy; } /** * 计算年终奖金 */ public function calculateBonus() { return $this->strategy->calculate($this->salary); }
}
/**
interface BonusStrategy
{
public function calculate($salary);
}
/**
class JuniorBonusStrategy implémente BonusStrategy
{
const RATIO = 0.2; public function calculate($salary) { return $salary * self::RATIO; }
}
/**
class IntermediateBonusStrategy implémente BonusStrategy
{
const RATIO = 0.5; public function calculate($salary) { return $salary * self::RATIO; }
}
/**
class SeniorBonusStrategy implémente BonusStrategy
{
const RATIO = 1; public function calculate($salary) { return $salary * self::RATIO; }
}
Dans cet exemple, nous avons une classe Employee pour représenter un objet employé. Il dispose d'une méthode calculateBonus, qui appellera un objet BonusStrategy passé pour calculer le bonus de fin d'année. Nous avons également défini une interface BonusStrategy et ses trois classes d'implémentation pour calculer les primes de fin d'année des employés de différents niveaux. Lors de l'exécution du code, nous pouvons créer des objets Employee en utilisant différents algorithmes.
Comment mettre en œuvre un modèle de stratégie en utilisant PHP ?
L'exemple ci-dessus implémente simplement le modèle de stratégie, mais en PHP, nous choisissons généralement de transmettre la stratégie comme méthode à l'objet contextuel. Différentes stratégies peuvent être transmises à l'objet contextuel au moment de l'exécution, et l'objet contextuel peut choisir arbitrairement parmi ces stratégies.
Ci-dessous, nous utiliserons un exemple simple pour illustrer comment implémenter le modèle de stratégie en PHP.
Tout d'abord, nous avons une interface de stratégie, qui définit une méthode de calcul.
interface TaxStrategy {
public function calculateTax($salary);
}
Nous pouvons implémenter une classe spécifique de l'interface TaxStrategy pour représenter une stratégie fiscale. Ce qui suit est une classe abstraite dans laquelle certaines méthodes et propriétés courantes sont implémentées.
classe abstraite AbstractTaxStrategy implémente TaxStrategy {
private $baseTax; public function __construct($baseTax) { $this->baseTax = $baseTax; } public function calculateTax($salary) { return $this->baseTax * $salary; }
}
Sur cette base, nous pouvons écrire une classe ConcreteTaxStrategy pour mettre en œuvre une stratégie fiscale spécifique. Dans cet exemple, nous définissons deux classes de stratégie spécifiques FlatTaxStrategy et ProgressiveTaxStrategy.
class FlatTaxStrategy extends AbstractTaxStrategy {
const TAX_RATE = .25; public function calculateTax($salary) { return $this->baseTax + ($salary * self::TAX_RATE); }
}
class ProgressiveTaxStrategy extends AbstractTaxStrategy {
const LOW_TAX_RATE = .20; const HIGH_TAX_RATE = .40; public function calculateTax($salary) { $lowTaxable = min($salary, 20000); $highTaxable = max(0, $salary - 20000); return $lowTaxable * self::LOW_TAX_RATE + ($highTaxable * self::HIGH_TAX_RATE) + $this->baseTax; }
}
Enfin, nous avons une classe de contexte, TaxContext. Il possède une variable membre $taxStrategy, qui représente la stratégie fiscale actuellement utilisée.
class TaxContext {
private $taxStrategy; public function __construct(TaxStrategy $taxStrategy) { $this->taxStrategy = $taxStrategy; } public function calculateTax($salary) { return $this->taxStrategy->calculateTax($salary); }
}
Dans cette classe de contexte, nous avons également une méthode calculateTax qui calculera la taxe en fonction de la stratégie actuellement utilisée.
Enfin, nous pouvons utiliser ensemble des classes de contexte et des classes de stratégie concrète.
$flatStrategy = new FlatTaxStrategy(10000);
$taxContext = new TaxContext($flatStrategy);
echo $taxContext->calculateTax(50000); // Output 12500
Évidemment, cet exemple n'est pas complètement spécifique, In en fait, il peut être étendu davantage en fonction de scénarios d’application spécifiques. Cependant, le modèle stratégique constitue sans aucun doute un moyen efficace d’améliorer l’évolutivité et la maintenabilité des logiciels.
Conclusion
Le modèle de stratégie est un modèle de conception concis et efficace qui peut encapsuler des algorithmes complexes et améliorer la lisibilité et la maintenabilité du code. Le modèle Stratégie vous offre un meilleur contrôle lorsque vous devez choisir un algorithme au moment de l'exécution. En PHP, vous pouvez implémenter le modèle de stratégie en passant des classes de stratégie spécifiques comme méthodes. Cette méthode reflète non seulement mieux l'idée de la programmation orientée objet, mais utilise également mieux la dynamique de PHP.
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!