Caja Negra
Enviado por jucearlo • 27 de Mayo de 2015 • 988 Palabras (4 Páginas) • 376 Visitas
Caja Negra:
En teoría de sistemas y física, se denomina caja negra a aquel elemento que es estudiado desde el punto de vista de las entradas que recibe y las salidas o respuestas que produce, sin tener en cuenta su funcionamiento interno. En otras palabras, de una caja negra nos interesará su forma de interactuar con el medio que le rodea (en ocasiones, otros elementos que también podrían ser cajas negras) entendiendo qué es lo que hace, pero sin dar importancia a cómo lo hace. Por tanto, de una caja negra deben estar muy bien definidas sus entradas y salidas, es decir, su interfaz; en cambio, no se precisa definir ni conocer los detalles internos de su funcionamiento.
Cuando de un subsistema se conocen sólo las entradas y las salidas pero no los procesos internos se dice que es una caja negra.
Un sistema formado por módulos que cumplan las características de caja negra será más fácil de entender ya que permitirá dar una visión más clara del conjunto. El sistema también será más robusto y fácil de mantener, en caso de ocurrir un fallo, éste podrá ser aislado y abordado más ágilmente.
En programación modular, donde un programa (o un algoritmo) es divido en módulos, en la fase de diseño se buscará que cada módulo sea una caja negra dentro del sistema global que es el programa que se pretende desarrollar, de esta manera se consigue una independencia entre los módulos que facilita su implementación separada por un equipo de trabajo donde cada miembro va a encargarse de implementar una parte (un módulo) del programa global; el implementador de un módulo concreto deberá conocer como es la comunicación con los otros módulos (la interfaz), pero no necesitará conocer como trabajan esos otros módulos internamente; en otras palabras, para el desarrollador de un módulo, idealmente, el resto de módulos serán cajas negras.
En pruebas de software, conociendo una función específica para la que fue diseñado el producto, se pueden diseñar pruebas que demuestren que cada función está bien resuelta. Dichas pruebas son llevadas a cabo sobre la interfaz del software.
Este enfoque produce la ventaja de identificar claramente los sistemas y subsistemas y estudiar las relaciones que existen entre ellos, permitiendo así maximizar la eficiencia de estas relaciones sin tener que introducirnos en los procesos complejos que se encuentran encerrados en una caja negra. Otra ventaja, especialmente en las empresas industriales, es que permite identificar los “cuellos de botellas”, es decir subsistemas que limitan la acción del sistema para lograr sus objetivos; también permite descubrir aquellos sistemas que son críticos.
en un
...