¿Cuál es la diferencia entre un marco y una biblioteca ?
Siempre pensé en una biblioteca como un conjunto de objetos y funciones que se centran en resolver un problema particular o un área específica de desarrollo de aplicaciones (es decir, acceso a la base de datos); y, por otro lado, un marco como una colección de bibliotecas centradas en una metodología particular (es decir, MVC) y que cubre todas las áreas de desarrollo de aplicaciones.
Respuestas:
En realidad, estos términos pueden significar muchas cosas diferentes dependiendo del contexto en el que se usan.
Por ejemplo, en Mac OS X, los marcos son solo bibliotecas, agrupadas en un paquete. Dentro del paquete encontrará una biblioteca dinámica real (libWhatever.dylib). La diferencia entre una biblioteca simple y el framework en Mac es que un framework puede contener múltiples versiones diferentes de la biblioteca. Puede contener recursos adicionales (imágenes, cadenas localizadas, archivos de datos XML, objetos de interfaz de usuario, etc.) y, a menos que el marco se publique, generalmente contiene los archivos .h necesarios que necesita para usar la biblioteca.
Por lo tanto, tiene todo dentro de un solo paquete que necesita para usar la biblioteca en su aplicación (una biblioteca C / C ++ / Objective-C sin archivos .h es bastante inútil, a menos que los escriba usted mismo de acuerdo con alguna documentación de la biblioteca), en lugar de un montón de archivos para moverse (un paquete de Mac es solo un directorio en el nivel Unix, pero la interfaz de usuario lo trata como un solo archivo, más o menos como si tuviera archivos JAR en Java y cuando hace clic en él, generalmente no ve lo que hay dentro, a menos que seleccione explícitamente mostrar el contenido).
Wikipedia llama a framework una "palabra de moda". Define un marco de software como
Entonces diría que una biblioteca es solo eso, "una biblioteca". Es una colección de objetos / funciones / métodos (dependiendo de su idioma) y su aplicación "enlaza" contra él y, por lo tanto, puede usar los objetos / funciones / métodos. Básicamente es un archivo que contiene código reutilizable que generalmente se puede compartir entre múltiples aplicaciones (no tiene que escribir el mismo código una y otra vez).
Un marco puede ser todo lo que usa en el desarrollo de aplicaciones. Puede ser una biblioteca, una colección de muchas bibliotecas, una colección de scripts o cualquier pieza de software que necesite para crear su aplicación. Marco es solo un término muy vago.
Aquí hay un artículo sobre un tipo sobre el tema " Biblioteca vs. Framework ". Personalmente, creo que este artículo es muy discutible. No está mal lo que dice allí, sin embargo, solo está eligiendo una de las múltiples definiciones de marco y compara eso con la definición clásica de biblioteca. Por ejemplo, dice que necesita un marco para subclasificar. De Verdad? Puedo tener un objeto definido en una biblioteca, puedo vincularlo y subclasificarlo en mi código. No veo cómo necesito un "marco" para eso. De alguna manera, más bien explica cómo se usa el término marco hoy en día. Es solo una palabra publicitada, como dije antes. Algunas compañías lanzan solo una biblioteca normal (en cualquier sentido de una biblioteca clásica) y la llaman un "marco" porque suena más elegante.
fuente
Una biblioteca realiza operaciones específicas bien definidas.
Un marco es un esqueleto donde la aplicación define la "carne" de la operación al completar el esqueleto. El esqueleto aún tiene código para vincular las partes, pero la aplicación realiza el trabajo más importante.
Ejemplos de bibliotecas: protocolos de red, compresión, manipulación de imágenes, utilidades de cadena, evaluación de expresiones regulares, matemáticas. Las operaciones son autónomas.
Ejemplos de marcos: sistema de aplicación web, administrador de complementos, sistema GUI. El marco define el concepto, pero la aplicación define la funcionalidad fundamental que les interesa a los usuarios finales.
fuente
Creo que la principal diferencia es que los marcos siguen el " principio de Hollywood ", es decir, "no nos llames, te llamaremos".
De acuerdo con Martin Fowler :
fuente
Tú llamas a la biblioteca.
Framework te llama.
fuente
Biblioteca:
Es solo una colección de rutinas (programación funcional) o definiciones de clase (programación orientada a objetos). La razón detrás es simplemente la reutilización del código , es decir, obtener el código que ya ha sido escrito por otros desarrolladores. Las clases o rutinas normalmente definen operaciones específicas en un área específica del dominio . Por ejemplo, hay algunas bibliotecas de matemáticas que pueden permitir al desarrollador simplemente llamar a la función sin rehacer la implementación de cómo funciona un algoritmo.
Marco de referencia:
En el marco, todo el flujo de control ya está allí, y hay un montón de puntos blancos predefinidos que debemos completar con nuestro código . Un marco es normalmente más complejo. Se define un esqueleto donde la aplicación define sus propias características para llenar el esqueleto. De esta forma, el marco llamará a su código cuando sea apropiado. El beneficio es que los desarrolladores no necesitan preocuparse por si un diseño es bueno o no, sino solo por implementar funciones específicas del dominio.
Biblioteca, marco y su representación de imagen de código:
Diferencia clave:
La diferencia clave entre una biblioteca y un marco es "Inversión de control" . Cuando llamas a un método desde una biblioteca, tienes el control. Pero con un marco, el control se invierte: el marco te llama . Fuente.
Relación:
Ambos definieron API, que se usa para que los programadores la usen. Para unirlos, podemos pensar en una biblioteca como una determinada función de una aplicación, un marco como el esqueleto de la aplicación y una API es un conector para unirlos. Un proceso de desarrollo típico normalmente comienza con un marco y completa funciones definidas en bibliotecas a través de API.
fuente
Como siempre lo he descrito:
Una biblioteca es una herramienta.
Un marco es una forma de vida.
Una biblioteca en la que puedes usar cualquier parte pequeña que te ayude. Un marco al que debe comprometer todo su proyecto.
fuente
Desde la perspectiva del desarrollador web:
La biblioteca puede ser fácilmente reemplazable por otra biblioteca. Pero el marco no puede.
Si no le gusta la biblioteca jquery date picker, puede reemplazarla con otro selector de fecha, como bootstrap date selector o pickadate.
Si no le gusta AngularJS en el que construyó su producto, no puede simplemente reemplazarlo con ningún otro marco. Tienes que reescribir toda tu base de código.
En su mayoría, la biblioteca toma menos curva de aprendizaje en comparación con Frameworks. Por ejemplo: underscore.js es una biblioteca, Ember.js es un framework.
fuente
Me gusta la respuesta de Cohens, pero una definición más técnica es: su código llama a una biblioteca. Un marco llama a tu código . Por ejemplo, un marco GUI llama a su código a través de controladores de eventos. Un marco web llama a su código a través de algún modelo de solicitud-respuesta.
Esto también se llama inversión de control : de repente, el marco decide cuándo y cómo ejecutar su código en lugar de lo contrario, como ocurre con las bibliotecas. Esto significa que un marco también tiene un impacto mucho mayor en cómo debe estructurar su código.
fuente
Olvidé dónde vi esta definición, pero creo que es bastante agradable.
Una biblioteca es un módulo al que llama desde su código, y un framework es un módulo que llama a su código.
fuente
Un marco puede estar hecho de diferentes bibliotecas. Pongamos un ejemplo.
Digamos que quieres cocinar un pescado al curry. Entonces necesitas ingredientes como aceite , especias y otras utilidades . También necesita pescado, que es su base para preparar su plato (Estos son datos de su aplicación). Todos los ingredientes juntos se llaman marco . Ahora los usará uno por uno o en combinación para preparar su pescado al curry, que es su producto final . Compare eso con un marco web que está hecho de underscore.js , bootstrap.css , bootstrap.js , fontawesome , AngularJS , etc. Por ejemplo, Twitter Bootstrap v.35.
Ahora, si considera solo un ingrediente, como decir aceite . No puedes usar el aceite que quieras porque arruinará tu pescado (datos). Solo puedes usar aceite de oliva . Compare eso con underscore.js . Ahora, qué marca de aceite desea utilizar depende de usted. Algunos platos se hicieron con aceite de oliva americano (underscore.js) o aceite de oliva indio (lodash.js). Esto solo cambiará el sabor de su aplicación. Dado que tienen casi el mismo propósito, su uso depende de la preferencia del desarrollador y son fácilmente reemplazables.
PS AngularJS es un marco MVC pero una biblioteca de JavaScript. Porque creo que Library extiende el comportamiento predeterminado de la tecnología nativa (JavaScript en este caso).
fuente
Así es como lo pienso (y he visto racionalizado por otros):
Una biblioteca es algo contenido en su código. Y un marco es un contenedor para su aplicación.
fuente
Aquí está vinculado un amargo artículo de Joel Spolsky , pero contiene una buena distinción entre cajas de herramientas, bibliotecas, marcos y demás.
fuente
Una biblioteca implementa la funcionalidad para un propósito de alcance limitado, mientras que un marco tiende a ser una colección de bibliotecas que brindan soporte para una gama más amplia de características. Por ejemplo, la biblioteca System.Drawing.dll maneja la funcionalidad de dibujo, pero es solo una parte del marco general .NET.
fuente
Biblioteca: cualquier conjunto de clases o componentes que se pueden usar según el cliente lo considere adecuado para realizar una determinada tarea.
Marco: exige ciertas pautas para que usted "se conecte" a algo más grande que usted. Simplemente proporciona las piezas específicas para su aplicación / requisitos de una manera requerida publicada, de modo que "el marco puede hacer su vida más fácil"
fuente
Las bibliotecas son fáciles de usar y eficientes. Puede decir, por ejemplo, que la biblioteca Zend nos ayuda a realizar diferentes tareas con sus clases y funciones bien definidas. Si bien un marco es algo que generalmente obliga a una determinada forma de implementar una solución, como MVC (Modelo -view-controller) (referencia) . Es un sistema bien definido para la distribución de tareas como en MVC. El modelo contiene el lado de la base de datos, las vistas son para la interfaz de usuario y los controladores son para la lógica de negocios.
fuente
Su interpretación me suena bastante bien ... Una biblioteca podría ser cualquier cosa compilada y autocontenida para su reutilización en otro código, literalmente no hay restricción en su contenido.
Por otro lado, se espera que un marco tenga una variedad de instalaciones para su uso en algún campo específico de desarrollo de aplicaciones, como su ejemplo, MVC.
fuente
Creo que usted precisó bastante bien la diferencia: el marco proporciona un marco en el que hacemos nuestro trabajo ... De alguna manera, es más "restrictivo" que una biblioteca simple.
También se supone que el marco agrega coherencia a un conjunto de bibliotecas.
fuente
Creo que la biblioteca es un conjunto de utilidades para alcanzar un objetivo (por ejemplo, sockets, criptografía, etc.). Framework es library + RUNTIME EINVIRONNEMENT. Por ejemplo, ASP.NET es un marco: acepta solicitudes HTTP, crea objetos de página, invoca eventos de lyfe cicle, etc. El marco hace todo esto, usted escribe un bit de código que se ejecutará en un momento específico del ciclo de vida de solicitud actual!
De todos modos, una pregunta muy interesante!
fuente
No recuerdo la fuente de esta respuesta (supongo que la encontré en un archivo .ppt en Internet), pero la respuesta es bastante simple.
Una Biblioteca y un Marco son un conjunto de clases, módulos y / o códigos (dependiendo del lenguaje de programación) que pueden usarse en sus aplicaciones y lo ayudan a resolver un "problema" específico.
Ese problema puede ser registrar o depurar información en una aplicación, dibujar gráficos, crear un formato de archivo específico (html, pdf, xls), conectarse a una base de datos, crear una parte de una aplicación o una aplicación completa o un código aplicado a un patrón de diseño .
Puede tener un Marco o una Biblioteca para resolver todos estos problemas y muchos más, normalmente los marcos lo ayudan a resolver problemas más complejos o más grandes, pero eso es una consecuencia de su principal diferencia, no una definición principal para ambos.
Esto significa que si un Framework tiene, por ejemplo, 50 clases para usar el framework en una aplicación que necesita usar, digamos, 10-15 o más clases en su código, porque así es como está diseñado un Framework, algunos Las clases (objetos de esas clases) son entradas / parámetros para métodos en otras clases en el marco. Vea el marco .NET, Spring o cualquier marco MVC.
Pero, por ejemplo, una biblioteca de registro, puede usar una clase de registro en su código y le ayuda a resolver el "problema de registro", eso no significa que la biblioteca de registro no tenga más clases en su código, como las clases para manejar archivos, manejar salidas de pantalla o incluso bases de datos, pero nunca toca / usa esas clases en su código, y esa es la razón por la cual es una biblioteca y no un marco.
Y también hay más categorías que Marcos y Bibliotecas, pero eso está fuera de tema.
fuente