El patrón de interfaz de marcador es un patrón de diseño en informática que se utiliza con lenguajes que proporcionan información de tipo de tiempo de ejecución sobre objetos. Proporciona un medio para asociar metadatos con una clase donde el lenguaje no tiene soporte explícito para dichos metadatos.
Para utilizar este patrón, una clase implementa una interfaz de marcador [1] (también llamada interfaz de etiquetado ) que es una interfaz vacía [2] y los métodos que interactúan con las instancias de esa clase prueban la existencia de la interfaz. Mientras que una interfaz típica especifica la funcionalidad (en forma de declaraciones de métodos) que una clase implementadora debe soportar, una interfaz de marcador no necesita hacerlo. La mera presencia de una interfaz de este tipo indica un comportamiento específico por parte de la clase implementadora. Las interfaces híbridas, que actúan como marcadores y especifican los métodos requeridos, son posibles pero pueden resultar confusas si se usan incorrectamente.
Un ejemplo de la aplicación de interfaces de marcadores del lenguaje de programación Java es la Serializable
interfaz:
paquete java.io ; Interfaz pública serializable { }
Una clase implementa esta interfaz para indicar que sus miembros de datos no transitorios se pueden escribir en un ObjectOutputStream
. El ObjectOutputStream
método privado writeObject0(Object,boolean)
contiene una serie de instanceof
pruebas para determinar la capacidad de escritura, una de las cuales busca la Serializable
interfaz. Si alguna de estas pruebas falla, el método arroja un NotSerializableException
.
Un problema importante con las interfaces de marcadores es que una interfaz define un contrato para implementar clases, y ese contrato es heredado por todas las subclases. Esto significa que no se puede "desimplementar" un marcador. En el ejemplo dado, si crea una subclase que no desea serializar (quizás porque depende del estado transitorio), debe recurrir a lanzar explícitamente NotSerializableException
(según ObjectOutputStream
la documentación)
Otra solución es que el lenguaje admita metadatos directamente:
implementsOnly
para declarar que no implementan todo lo de sus superclases.Java eficaz [1] por Joshua Bloch .
{{cite book}}
: Mantenimiento de CS1: falta la ubicación del editor ( enlace )