<?xml version="1.0"?>
<rss version="2.0">
   <channel>
      <title>SOLID by Samuel Reyes</title>
      <link>https://padlet.com/poo510/fzbdqlb1772iwwb6</link>
      <description>Principios SOLID</description>
      <language>en-us</language>
      <pubDate>2023-06-29 04:16:36 UTC</pubDate>
      <lastBuildDate>2023-07-06 15:48:23 UTC</lastBuildDate>
      <webMaster>hello@padlet.com</webMaster>
      <image>
         <url></url>
      </image>
      <item>
         <title>Segregación De Interfaces</title>
         <author>samucoreyes</author>
         <link>https://padlet.com/poo510/fzbdqlb1772iwwb6/wish/2634854208</link>
         <description><![CDATA[<div><br>El principio de segregación de interfaces, establece que "los clientes no deben ser forzados a depender de interfaces que no utilizan". En otras palabras, este principio promueve la idea de dividir interfaces grandes y poco cohesivas en interfaces más pequeñas y específicas, de modo que los clientes solo dependan de las interfaces que realmente necesitan. La razón detrás de este principio es evitar la creación de interfaces sobrecargadas o monolíticas que obliguen a las clases o módulos a depender de funcionalidades innecesarias o irrelevantes para su contexto. Si una interfaz es demasiado grande, puede llevar a una mayor dependencia y acoplamiento innecesario entre los componentes del sistema.<br><br></div><div>Al aplicar el principio de segregación de interfaces, se busca diseñar interfaces cohesivas y enfocadas en un conjunto específico de responsabilidades. Esto permite que los clientes implementen solo las interfaces relevantes para ellos y evita que se vean afectados por cambios en otras partes del sistema.<br><br></div><div><br><br></div>]]></description>
         <enclosure url="" />
         <pubDate>2023-06-29 04:19:25 UTC</pubDate>
         <guid>https://padlet.com/poo510/fzbdqlb1772iwwb6/wish/2634854208</guid>
      </item>
      <item>
         <title>Principio de Abierto/Cerrado</title>
         <author>wamedinacarrion</author>
         <link>https://padlet.com/poo510/fzbdqlb1772iwwb6/wish/2634890849</link>
         <description><![CDATA[<div>Se refiere a un principio de diseño de software que promueve la extensibilidad y la modularidad del código.<br><br>En otras palabras, cuando se aplica el principio de abierto/cerrado, se busca diseñar componentes de software de manera que puedan ser extendidos o mejorados sin tener que modificar el código existente.<br><br>Una de la técnica más usada para este principio es el polimorfismo, en el cual se utiliza herencia e interfaces, se puede definir una estructura base común para las entidades y luego extenderlas con comportamientos específicos sin modificar la estructura base.</div>]]></description>
         <enclosure url="https://files.merca20.com/uploads/2017/07/programacion.jpg" />
         <pubDate>2023-06-29 05:08:16 UTC</pubDate>
         <guid>https://padlet.com/poo510/fzbdqlb1772iwwb6/wish/2634890849</guid>
      </item>
      <item>
         <title>Principio de Sustitución de Liskov</title>
         <author></author>
         <link>https://padlet.com/poo510/fzbdqlb1772iwwb6/wish/2634891588</link>
         <description><![CDATA[<div>El principio de sustitución de Liskov establece que si una clase A es un subtipo de una clase B, entonces los objetos de tipo B pueden ser reemplazados por objetos de tipo A sin alterar el comportamiento del programa.</div>]]></description>
         <enclosure url="" />
         <pubDate>2023-06-29 05:09:06 UTC</pubDate>
         <guid>https://padlet.com/poo510/fzbdqlb1772iwwb6/wish/2634891588</guid>
      </item>
      <item>
         <title>El principio de Responsabilidad Unica</title>
         <author></author>
         <link>https://padlet.com/poo510/fzbdqlb1772iwwb6/wish/2635255288</link>
         <description><![CDATA[<div><br>El principio de responsabilidad única (SRP) es un principio de diseño de software que establece que cada módulo, clase o función debe tener una única responsabilidad o tarea. Al aplicar este principio, se logra un código más cohesivo, con menos acoplamiento y más fácil de mantener. Cada componente se enfoca en una única tarea y no tiene conocimiento de las demás responsabilidades del sistema. Esto facilita el mantenimiento, la reutilización y la comprensión del código, y también mejora la escalabilidad y las pruebas unitarias. En resumen, el SRP promueve la creación de componentes de software más claros y eficientes al asignarles una única responsabilidad.&nbsp;<br><br>Un ejemplo de SRP es:&nbsp;<br><br></div><ol><li>Gestión de usuarios: Una clase o módulo que se encarga únicamente de la creación, autenticación y gestión de usuarios en un sistema. No debe tener la responsabilidad de realizar operaciones relacionadas con la lógica de negocios o el procesamiento de datos.</li></ol><div><br></div>]]></description>
         <enclosure url="https://padlet-uploads.storage.googleapis.com/2082611417/82b847dcef1dc5f3646c4eab38ddae6b/image.png" />
         <pubDate>2023-06-29 15:42:17 UTC</pubDate>
         <guid>https://padlet.com/poo510/fzbdqlb1772iwwb6/wish/2635255288</guid>
      </item>
      <item>
         <title>El principio de inversión de la dependencia </title>
         <author></author>
         <link>https://padlet.com/poo510/fzbdqlb1772iwwb6/wish/2635269326</link>
         <description><![CDATA[<div>En el diseño orientado a objetos, el principio de inversión de dependencia es una forma específica de desacoplar módulos de software. Al seguir este principio, las relaciones de dependencia convencionales establecidas desde los módulos de alto nivel de establecimiento de políticas a los módulos de dependencia de bajo nivel se invierten, lo que hace que los módulos de alto nivel sean independientes de los detalles de implementación del módulo de bajo nivel. El principio establece:&nbsp;<br><br>-Los módulos de alto nivel no deberían depender de los módulos de bajo nivel. Ambos deberían depender de abstracciones (p.ej., interfaces).<br>-Las abstracciones no deberían depender de los detalles. Los detalles (implementaciones concretas) deben depender de abstracciones.<br>Módulos de alto nivel: se refieren a los objetos que definen el qué es y qué hace tu programa. Aquellos que contienen la lógica de negocio y cómo interactúa el software entre sí. Son los objetos más importantes del programa. Por ejemplo, en una aplicación de un banco, podría ser el objeto que se encarga de devolver la lista de cuentas bancarias.<br>Módulos de bajo nivel: son aquellos objetos que no están directamente relacionados con la lógica de negocio del programa. Por ejemplo, el mecanismo de persistencia (CoreData, Realm, MySQL, etc…) o el mecanismo de acceso a red (URLSession, Alamofire, AFNetworking, etc…). Son objetos menos importantes, de los cuales no depende la lógica de negocio.<br>Abstracciones: se refieren a Tipos de Datos que no son las implementaciones concretas, si no los que definen la interfaz pública. Serán, por tanto, protocolos (o interfaces) o clases abstractas (*en Swift no existen las clases abstractas como tal)</div>]]></description>
         <enclosure url="" />
         <pubDate>2023-06-29 16:13:01 UTC</pubDate>
         <guid>https://padlet.com/poo510/fzbdqlb1772iwwb6/wish/2635269326</guid>
      </item>
   </channel>
</rss>
