Créer une API asynchrone/non-asynchrone robuste
Développer des bibliothèques réutilisables qui gèrent les E/S réseau nécessite souvent de proposer des méthodes à la fois asynchrones (async) et synchrones (non async). Utiliser simplement Wait()
pour créer une version synchrone à partir d'une version asynchrone est inefficace. Cet article présente une solution pour conserver les deux options tout en préservant l'intégrité de la conception de l'API.
Donner la priorité à l'Async : la meilleure approche
Pour une maintenabilité optimale, pensez à concevoir votre API exclusivement avec des méthodes asynchrones. Cela élimine la duplication de code et favorise la cohérence. Implémentez ces méthodes asynchrones à l'aide d'opérations non bloquantes pour éviter une utilisation inutile du pool de threads et garantir les performances.
Naviguer dans le compromis asynchrone/non-asynchrone
Fournir des méthodes asynchrones et non asynchrones présente un défi de maintenance important. La duplication de code n'est pas souhaitable, et le simple fait d'encapsuler un type de méthode dans un autre (comme discuté par Stephen Toub) n'est pas une solution idéale.
Le « Boolean Argument Hack » : une solution pragmatique
Une technique pratique pour éviter la duplication de code est le « hack d'argument booléen ». Cela implique d'ajouter un paramètre booléen à votre méthode, indiquant si un comportement synchrone ou asynchrone est souhaité. La logique interne de la méthode gère alors les deux scénarios.
Bien que cette approche ajoute un certain degré de complexité, elle réduit considérablement les frais de maintenance par rapport à la gestion d'implémentations distinctes. L'adéquation de ce hack dépend du contexte spécifique et de l'équilibre entre maintenabilité et élégance de la conception de l'API.
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!