Modèles de conception Python - Adaptateur

Le modèle d'adaptateur fonctionne comme un pont entre deux interfaces incompatibles. Ce type de modèle de conception relève d'un modèle structurel car ce modèle combine la capacité de deux interfaces indépendantes.

Ce modèle implique une seule classe, qui est chargée de joindre les fonctionnalités d'interfaces indépendantes ou incompatibles. Un exemple concret pourrait être le cas d'un lecteur de carte, qui agit comme un adaptateur entre la carte mémoire et un ordinateur portable. Vous branchez la carte mémoire dans le lecteur de carte et le lecteur de carte dans l'ordinateur portable afin que la carte mémoire puisse être lue via l'ordinateur portable.

Le modèle de conception de l'adaptateur permet de travailler les classes ensemble. Il convertit l'interface d'une classe en une autre interface en fonction des besoins. Le modèle comprend une spéciation d'un polymorphisme qui nomme un nom et plusieurs formes. Disons pour une classe de forme qui peut utiliser selon les exigences rassemblées.

Il existe deux types de modèle d'adaptateur -

Modèle d'adaptateur d'objet

Ce modèle de conception repose sur l'implémentation d'objets. Par conséquent, il est appelé modèle d'adaptateur d'objet.

Modèle d'adaptateur de classe

Il s'agit d'une autre manière d'implémenter le modèle de conception d'adaptateur. Le modèle peut être implémenté à l'aide de plusieurs héritages.

Comment implémenter le modèle d'adaptateur?

Voyons maintenant comment implémenter le modèle d'adaptateur.

class EuropeanSocketInterface:
   def voltage(self): pass

   def live(self): pass
   def neutral(self): pass
   def earth(self): pass

# Adaptee
class Socket(EuropeanSocketInterface):
   def voltage(self):
      return 230

	def live(self):
      return 1
   
   def neutral(self):
      return -1
   
   def earth(self):
      return 0

# Target interface
class USASocketInterface:
   def voltage(self): pass
   def live(self): pass
   def neutral(self): pass

# The Adapter
class Adapter(USASocketInterface):
   __socket = None
   def __init__(self, socket):
      self.__socket = socket
   
   def voltage(self):
      return 110
   
   def live(self):
      return self.__socket.live()
   
   def neutral(self):
      return self.__socket.neutral()

# Client
class ElectricKettle:
   __power = None
   
   def __init__(self, power):
	   self.__power = power
   
   def boil(self):
      if self.__power.voltage() > 110:
         print "Kettle on fire!"
      else:
         if self.__power.live() == 1 and \
            self.__power.neutral() == -1:
            print "Coffee time!"
         else:
            print "No power."

def main():
   # Plug in
   socket = Socket()
   adapter = Adapter(socket)
   kettle = ElectricKettle(adapter)
	
   # Make coffee
   kettle.boil()
	
   return 0
	
if __name__ == "__main__":
   main()

Production

Le programme ci-dessus génère la sortie suivante -

Explication

Le code comprend une interface d'adaptateur avec divers paramètres et attributs. Il inclut Adaptee avec l'interface cible qui implémente tous les attributs et affiche la sortie comme visible.