Tutoriales de programación - página 2

 

Programación orientada a objetos en 7 minutos | Mosh



Programación orientada a objetos en 7 minutos | Mosh

La programación orientada a objetos (POO) revolucionó la forma en que abordamos el desarrollo de software al introducir cuatro conceptos básicos: encapsulación, abstracción, herencia y polimorfismo. Estos conceptos proporcionan un marco poderoso y organizado para diseñar e implementar sistemas complejos.

La encapsulación es la práctica de agrupar variables y funciones relacionadas en una unidad llamada objeto. Al encapsular datos y los métodos que operan con esos datos dentro de un objeto, creamos una entidad autónoma con límites bien definidos. Por ejemplo, un objeto de automóvil puede tener propiedades como marca, modelo y color, así como métodos como iniciar, detener y mover. Esta encapsulación nos permite manipular e interactuar con el objeto del automóvil como una sola entidad, ocultando los detalles de implementación internos del mundo exterior. La encapsulación no solo mejora la organización del código, sino que también mejora la reutilización y el mantenimiento del código.

La abstracción es el proceso de ocultar detalles de implementación complejos y exponer solo características o interfaces esenciales. Nos permite crear representaciones simplificadas de objetos o conceptos del mundo real. Al igual que un reproductor de DVD abstrae su intrincada lógica interna detrás de unos pocos botones, los objetos en OOP pueden ocultar su funcionamiento interno al tiempo que proporcionan una interfaz clara y concisa. Al abstraer la complejidad, podemos reducir la carga cognitiva y hacer que nuestro código sea más comprensible. Además, la abstracción actúa como un escudo protector, aislando el impacto de los cambios dentro de un objeto y evitando consecuencias no deseadas en otras partes del código base.

La herencia es un mecanismo que permite que los objetos hereden propiedades y comportamientos de otros objetos. Con la herencia, podemos crear una jerarquía de objetos, donde los objetos más especializados heredan características de objetos más generalizados. Esta jerarquía promueve la reutilización del código, ya que los atributos y métodos comunes se pueden definir en un objeto base y heredar por sus subclases. Por ejemplo, en el caso de elementos HTML, como cuadros de texto, listas desplegables y casillas de verificación, todos comparten propiedades comunes como HTML interno y oculto, así como métodos como hacer clic y enfocar. En lugar de duplicar estas propiedades y métodos en cada elemento HTML, podemos definirlos una vez en un objeto genérico llamado elemento HTML y hacer que los elementos específicos hereden de él. La herencia elimina la redundancia, mejora la capacidad de mantenimiento del código y permite arquitecturas de código flexibles y extensibles.

El polimorfismo, derivado de las palabras griegas "poly" (muchos) y "morph" (forma), se refiere a la capacidad de los objetos para adoptar múltiples formas o comportamientos. En OOP, el polimorfismo permite que objetos de diferentes tipos sean tratados como objetos de un tipo común. Este concepto se logra mediante la anulación de métodos y la sobrecarga de métodos. La anulación de métodos permite que una subclase proporcione su propia implementación de un método heredado de su superclase. Por ejemplo, es posible que sea necesario representar diferentes elementos HTML en una página, pero cada elemento tiene su comportamiento de representación único. Al implementar un método de representación en cada objeto, podemos lograr polimorfismo y simplificar el código, eliminando largas declaraciones if-else o switch-case. La sobrecarga de métodos, por otro lado, permite que múltiples métodos con el mismo nombre pero diferentes listas de parámetros coexistan dentro de una clase. El polimorfismo permite la flexibilidad del código, mejora la legibilidad del código y promueve el principio de "programación para una interfaz" en lugar de una implementación específica.

Al aprovechar la encapsulación, la abstracción, la herencia y el polimorfismo, la programación orientada a objetos proporciona un enfoque estructurado para el desarrollo de software. Brinda numerosos beneficios, como la organización del código, la reutilización, la capacidad de mantenimiento, la modularidad y la extensibilidad. La comprensión y la aplicación efectiva de estos conceptos básicos permiten a los desarrolladores crear sistemas complejos que sean flexibles, escalables y más fáciles de comprender y mantener a lo largo del tiempo.

Object-oriented Programming in 7 minutes | Mosh
Object-oriented Programming in 7 minutes | Mosh
  • 2018.03.29
  • www.youtube.com
Get the COMPLETE COURSE: http://bit.ly/2keDCna4 pillars of object-oriented programming: encapsulation, abstraction, inheritance and polymorphism. Subscribe f...
 

Introducción a la Programación Orientada a Objetos - Curso intensivo


Introducción a la Programación Orientada a Objetos - Curso intensivo

Bienvenido a una introducción a la programación orientada a objetos. En este curso, exploraremos el concepto de programación orientada a objetos y sus cuatro principios fundamentales. Se supone que tienes conocimientos previos de programación, pero si eres nuevo en la programación, te recomendamos ver nuestro video de introducción a la programación, que está vinculado en la descripción.

La programación orientada a objetos nos permite agrupar variables de tipos similares, lo que facilita la gestión de programas complejos. En el pasado, los tipos de datos primitivos como byte, int, float, double, boolean y char se usaban para almacenar valores simples únicos. Sin embargo, a medida que los programas se volvían más complejos, los programadores necesitaban una forma de agrupar las variables relacionadas.

Esto llevó al desarrollo de estructuras en C, que permitieron agrupar datos de diferentes tipos. Las estructuras fueron una mejora con respecto a los arreglos, ya que permitieron el almacenamiento de diversos datos. Sin embargo, las estructuras carecían de la capacidad de definir funciones dentro de ellas.

Con el advenimiento de la programación orientada a objetos, se introdujeron los objetos. Un objeto es una instancia de una clase, que sirve como plantilla para objetos. Los objetos pueden almacenar datos y definir funciones. La clase define los atributos y comportamientos comunes de los objetos, mientras que los objetos representan instancias específicas con sus propios datos únicos.

La encapsulación es uno de los principios fundamentales de la programación orientada a objetos. Implica agrupar datos y métodos dentro de una clase y ocultarlos del acceso externo. Otras clases pueden interactuar con los atributos de un objeto solo a través de los métodos de la clase, como los métodos getter y setter. La encapsulación ayuda a mantener el control de los datos y reduce la complejidad del programa al evitar el acceso directo a los atributos internos.

La abstracción es otro principio que se enfoca en mostrar detalles esenciales mientras oculta complejidades innecesarias. En programación, esto significa definir interfaces para clases que permitan la comunicación entre diferentes secciones de código. La implementación exacta de los métodos está oculta dentro de la clase y las clases externas solo interactúan con la interfaz definida. Este enfoque permite la programación modular y facilita la colaboración entre múltiples programadores.

En las siguientes secciones, discutiremos los principios restantes de la programación orientada a objetos: herencia y polimorfismo. Estos principios mejoran aún más la flexibilidad y la reutilización del código en la programación orientada a objetos.

Eso es todo por la introducción a la programación orientada a objetos. Pasemos a la siguiente sección y exploremos la encapsulación con más detalle.

  • 00:00:00 En esta lección, exploraremos qué es la programación orientada a objetos y cómo funciona. Analizaremos cómo funcionan los tipos de datos primitivos, como bytes, enteros, flotantes, dobles y booleanos, y cómo las estructuras pueden ayudar a organizar y almacenar datos de manera más eficiente. También exploraremos cómo se crean los objetos y cómo se relacionan entre sí.

  • 00:05:00 La programación orientada a objetos proporciona una forma de agrupar datos y funciones relacionados, lo que permite una programación compleja sin tener que codificar todo por separado. En este Curso intensivo, veremos el primero de los cuatro principios principales de la programación orientada a objetos: la encapsulación. Veremos cómo se usa esto en el contexto del ejemplo de ajedrez de la sección anterior, y cómo facilita el seguimiento y la administración de atributos relacionados.

  • 00:10:00 La abstracción es la idea de ocultar detalles esenciales de los usuarios de una clase, mientras que la encapsulación es la práctica de ocultar datos de otras clases. Estos conceptos son importantes cuando se trabaja en programas grandes y complejos, ya que puede ser difícil concentrarse en el panorama general durante la programación. Esta sección discutirá el cuarto principio de la programación orientada a objetos, la abstracción.

  • 00:15:00 En la programación orientada a objetos, una interfaz es un conjunto predeterminado de métodos que dos clases pueden usar para comunicarse entre sí. Esto evita que diferentes partes del programa se acoplen por completo y ayuda a evitar errores en la comunicación. la herencia es el principio que permite que una clase derive otras clases de ella, y en este video veremos un ejemplo.

  • 00:20:00 En este curso acelerado sobre programación orientada a objetos, discutimos los tres principales modificadores de acceso: público, privado y protegido. También analizamos el polimorfismo, que describe métodos que pueden tomar muchas formas. Finalmente, discutimos el principio de herencia, que describe cómo las clases pueden relacionarse entre sí.

  • 00:25:00 El polimorfismo es la capacidad de un método para tomar diferentes formas dependiendo de la jerarquía de clases desde la que se llama. Esto funciona tanto dinámica como estáticamente. La sobrecarga permite que los métodos con el mismo nombre tengan efectos diferentes, pero es potencialmente complicado de implementar.

  • 00:30:00 Este video presenta los conceptos básicos de la Programación Orientada a Objetos (POO). Si está interesado en aprender más sobre OOP, asegúrese de ver otros videos en la serie Crash Course.
Intro to Object Oriented Programming - Crash Course
Intro to Object Oriented Programming - Crash Course
  • 2020.09.30
  • www.youtube.com
Learn the basics of object-oriented programming all in one video.✏️ Course created by Steven from NullPointer Exception. Check out their channel: https://www...
 

C++ OOP - Introducción a clases y objetos para principiantes



C++ OOP - Introducción a clases y objetos para principiantes

¡Bienvenidos a mi canal, todos! Soy Saldina y creo videos relacionados con la informática y la programación. Si estás interesado en esos temas, considera suscribirte a mi canal y darle a este video un pulgar hacia arriba.

En este video quiero adentrarme en el mundo de la programación orientada a objetos (POO). Entonces, ¿qué es exactamente la programación orientada a objetos? OOP nos permite representar objetos de la vida real en programación, completos con sus atributos y comportamientos.

Dos conceptos fundamentales en POO son las clases y los objetos. Entendamos la diferencia entre los dos. Una clase sirve como plantilla o modelo, definiendo la estructura y el comportamiento de un objeto. Por otro lado, un objeto es una instancia de una clase. Para ilustrar esto, considere una clase que represente frutas, y los objetos de esa clase podrían ser una manzana, un plátano o un melocotón. De manera similar, una clase que represente automóviles tendría objetos como Volvo, Ford o BMW. Cada clase tiene atributos (propiedades) como nombre, precio, velocidad máxima y color, así como comportamientos (métodos) como conducir, frenar y cambiar de color.

Ahora, creemos una clase de ejemplo llamada "YouTubeChannel". Para crear una clase, usamos la palabra clave "clase" seguida del nombre de la clase entre llaves. También necesitamos hacer que los miembros de la clase sean accesibles fuera de la clase usando el modificador de acceso "público". En nuestra clase YouTubeChannel, definiremos atributos como el nombre del canal, el nombre del propietario, el número de suscriptores y una lista de títulos de videos publicados. Para representar estos atributos, les asignamos valores. Creamos un objeto de la clase YouTubeChannel y accedemos a sus propiedades usando la notación de puntos. Por ejemplo, podemos asignar el nombre del canal de YouTube como "CodeBeauty" y el nombre del propietario como "Saldina".

También podemos establecer el recuento de suscriptores en 1800 y agregar tres títulos de video publicados a la lista. Para mostrar la información almacenada en estas propiedades, usamos "cout" para imprimirlas. Para la lista de títulos de videos publicados, que es una colección, podemos iterar sobre ella usando un bucle e imprimir cada título de video. Al ejecutar el programa, podemos ver el resultado que muestra los detalles del canal de YouTube: el nombre del canal, el nombre del propietario, el número de suscriptores y la lista de títulos de videos publicados.

En videos futuros, cubriremos temas como constructores y métodos de clase, que brindan enfoques más simplificados para trabajar con clases y objetos.

¡Espero que hayas disfrutado este video! Si te resultó útil, dale me gusta y considera suscribirte a mi canal haciendo clic en el ícono de la campana. Estén atentos para más contenido emocionante. Nos vemos en el próximo vídeo. ¡Adiós!

C++ OOP - Introduction to classes and objects for beginners
C++ OOP - Introduction to classes and objects for beginners
  • 2020.08.02
  • www.youtube.com
Object-oriented programming is a programming paradigm that is based on the concept of objects from the real world, and it is used to represent those real wor...
 

C++ OOP (2020): ¿qué son los constructores y los métodos de clase? ¿Cómo usarlos?


C++ OOP (2020): ¿qué son los constructores y los métodos de clase? ¿Cómo usarlos?

Hola a todos, bienvenidos a mi canal! Soy Saldina y en este canal creo videos relacionados con la programación. Si eso te interesa, considera suscribirte y darle a este video un pulgar hacia arriba. En este video, quiero hablar sobre constructores y métodos de clase.

En un tutorial anterior, escribimos un código para una clase llamada YouTubeChannel. Tiene cuatro propiedades públicas: nombre, nombre del propietario, recuento de suscriptores y una lista de títulos de videos publicados. Creamos un objeto de esa clase y asignamos valores a sus propiedades. Ahora, abordemos un problema con este enfoque. Si queremos crear otro objeto de canal de YouTube, tendríamos que copiar y pegar el código y realizar los cambios correspondientes. Esto viola el principio de "No te repitas". Para resolver este problema, podemos usar constructores y métodos de clase.

Un constructor es un método especial que se invoca cuando se crea un objeto. Tiene el mismo nombre que la clase y no tiene un tipo de devolución. Creemos un constructor para la clase YouTubeChannel. Recibirá dos parámetros: nombre y nombre del propietario. Dentro del constructor, asignaremos estos parámetros a las propiedades correspondientes. Después de crear el constructor, podemos usarlo para crear objetos pasando los valores requeridos. Esto elimina la necesidad de repetir el código para crear objetos. También podemos usar métodos de clase para evitar repetir código para mostrar información sobre los canales.

Vamos a crear un método de clase llamado getInfo que escriba la información del canal. Podemos mover el código para mostrar la información a este método y usarlo para ambos objetos. Para invocar el método getInfo, podemos llamarlo en el objeto usando el nombre del objeto seguido de un punto y el nombre del método. De esta manera, podemos mostrar la información de ambos canales sin duplicar el código.

Mediante el uso de constructores y métodos de clase, logramos un código más limpio y eficiente. La función principal se vuelve más fácil de leer y mantener. Los constructores manejan la inicialización de las propiedades del objeto, mientras que los métodos de clase encapsulan los comportamientos comunes de la clase.

Espero que hayas encontrado útil este video. Si te gustó, por favor dale me gusta y suscríbete a mi canal. No olvides presionar el ícono de la campana para mantenerte actualizado. Te veré en mi próximo video. ¡Adiós!

C++ OOP (2020) - What are constructors and class methods? How to use them?
C++ OOP (2020) - What are constructors and class methods? How to use them?
  • 2020.08.09
  • www.youtube.com
In this video, I'm explaining when, why, and how are constructors and class methods used.📚 Learn how to solve problems and build projects with these Free E-...
 

C++ OOP - ¿Qué es la encapsulación en la programación?



C++ OOP - ¿Qué es la encapsulación en la programación?

¡Hola a todos! Soy Saldina, y bienvenidos a mi canal relacionado con la programación. Si está interesado en la programación, considere suscribirse y darle a este video un pulgar hacia arriba. En este video, discutiremos la encapsulación.

Primero, repasemos rápidamente el código de nuestros videos anteriores. Tenemos una clase YouTubeChannel con atributos públicos: nombre, nombre del propietario, número de suscriptores y una lista de títulos de videos publicados. También tenemos un constructor YouTubeChannel y un método getInfo.

Ahora, concentrémonos en la encapsulación. El principio de encapsulación establece que las propiedades deben ser privadas y sus valores deben ser accedidos y modificados a través de métodos expuestos por la clase. Esto asegura una manipulación de datos controlada y adecuada. Para demostrar la necesidad de la encapsulación, presentemos un problema. Actualmente, podemos asignar directamente un valor al recuento de suscriptores, que no es cómo los suscriptores deberían aumentar o disminuir naturalmente. En su lugar, debemos proporcionar métodos como suscribirse y darse de baja para controlar estos cambios.

Para ocultar las propiedades a los usuarios, las haremos privadas. Al cambiar su modificador de acceso a privado, restringimos el acceso directo a estas propiedades. Sin embargo, esto genera errores ya que los miembros privados ahora son inaccesibles fuera de la clase. Para permitir que los usuarios modifiquen el conteo de suscriptores, creamos dos métodos: suscribirse y darse de baja. El método de suscripción incrementa el número de suscriptores, mientras que el método de cancelación de suscripción lo disminuye. Al usar estos métodos, los usuarios pueden interactuar con la clase y seguir las reglas definidas por los métodos.

Hemos encontrado un problema en el método de cancelación de suscripción. Actualmente permite que el recuento se vuelva negativo. Para solucionar esto, debemos agregar una verificación que asegure que el conteo sea mayor que cero antes de disminuirlo. Además, tenemos otra propiedad privada, títulos de videos publicados, que ahora es inaccesible. Para proporcionar acceso a esta propiedad, crearemos un método denominadopublishVideo. Este método toma un parámetro de cadena (el título del video) y lo agrega a la lista de títulos de videos publicados usando el método push_back.

Finalmente, hemos expuesto métodos que permiten a los usuarios interactuar con la clase y manipular las propiedades privadas. Para controlar aún más el acceso a las propiedades del nombre y el nombre del propietario, podemos crear métodos getter y setter.

Para resumir la encapsulación:

  • Haga que las propiedades sean privadas para restringir el acceso directo.
  • Proporcione métodos públicos para modificar las propiedades privadas.
  • Asegure la manipulación adecuada de los datos siguiendo las reglas definidas en los métodos.

Si tiene algún código que implemente métodos getter y setter, no dude en compartirlo en la sección de comentarios para su revisión.

Si disfrutaste este video, dale me gusta, suscríbete a mi canal y haz clic en el icono de la campana para recibir notificaciones de futuros videos. ¡Gracias por mirar, y nos vemos en el próximo video! ¡Adiós!

C++ OOP - What is encapsulation in programming?
C++ OOP - What is encapsulation in programming?
  • 2020.08.17
  • www.youtube.com
Encapsulation is one of the most important characteristics of Object-Oriented Programming. Encapsulation helps in data hiding and is used to prevent direct a...
 

C++ OOP - ¿Qué es la herencia en la programación?



C++ OOP - ¿Qué es la herencia en la programación?

Hola a todos, soy Saldina y creo videos relacionados con la programación. Si estás interesado en eso, considera suscribirte a mi canal. Además, dale a este video un pulgar hacia arriba. En este video, quiero hablar sobre la encapsulación.

He escrito algo de código en videos anteriores de este curso. Si no los has visto, asegúrate de echarles un vistazo. Proporcionaré enlaces en la descripción del video. Déjame repasar rápidamente el código para ayudarte a entenderlo. Creé una clase YouTubeChannel con cuatro atributos públicos: nombre, nombre del propietario, número de suscriptores y una lista de títulos de videos publicados. El constructor YouTubeChannel y el método getInfo también están presentes. Puedes ver el código del constructor aquí.

En la función principal, creé un objeto de la clase YouTubeChannel y asigné valores para el nombre y el nombre del propietario. También he agregado tres videos a la lista de videos publicados. Finalmente, imprimí información sobre el canal. Ahora, hablemos de la encapsulación. Este principio sugiere que estas propiedades deben ser privadas, no públicas. Los datos almacenados en estas propiedades solo deben modificarse a través de métodos que exponga al usuario. Siguiendo las reglas de estos métodos, el usuario puede cambiar los valores de propiedad.

Consideremos un problema para entender por qué necesitamos encapsulación. ¿Qué sucede si configuro el número de suscriptores de este canal de YouTube en un millón? Esto no debería permitirse. Si ejecuto el código, verás que el canal ahora tiene un millón de suscriptores. Sin embargo, obtener suscriptores naturalmente requiere que los usuarios invoquen los métodos de suscripción y cancelación de suscripción. Mediante el uso de estos métodos, el número de suscriptores aumenta o disminuye. Para ocultar estas propiedades al usuario, las hacemos privadas en lugar de públicas. Esto significa que solo se puede acceder a ellos dentro de la propia clase. Para permitir que los usuarios modifiquen el recuento de suscriptores, creamos dos métodos: suscribirse y darse de baja. El método de suscripción incrementa el número de suscriptores, mientras que el método de cancelación de suscripción lo disminuye.

Para aumentar o disminuir los suscriptores, ahora tenemos que invocar estos métodos. Por ejemplo, youtubeChannel.subscribe() se usa tres veces para simular tres suscripciones. Si invoco youtubeChannel.unsubscribe() y luego llamo a getInfo, verá que hay dos suscriptores. También encontramos un error de tiempo de compilación porque la propiedad de títulos de video publicados ahora es privada e inaccesible. Para resolver esto, creamos un método llamadopublishVideo, que agrega un título de video a la lista de títulos de videos publicados. El método toma un parámetro de título, lo que permite al usuario especificar el título del video. Al invocar youtubeChannel.publishVideo("Título"), agregamos videos a la lista.

En resumen, la encapsulación implica hacer que las propiedades sean privadas y proporcionar métodos públicos para modificarlas. Los métodos getter y setter se pueden usar para acceder y cambiar propiedades específicas. Siéntase libre de compartir su implementación de los métodos getter y setter en los comentarios para su revisión.

Si este video te resultó útil, dale me gusta, suscríbete a mi canal y haz clic en el ícono de la campana. Estén atentos para más videos. ¡Hasta la próxima! ¡Adiós!

C++ OOP - What is inheritance in programming?
C++ OOP - What is inheritance in programming?
  • 2020.08.20
  • www.youtube.com
Inheritance is one of the most important characteristics of Object-Oriented Programming. Inheritance is a process in which one class (aka derived class/child...
 

C++ OOP - ¿Qué es el polimorfismo en la programación? (ejemplo sencillo)



C++ OOP - ¿Qué es el polimorfismo en la programación? (ejemplo sencillo)

Hola a todos, bienvenidos a mi canal. Mi nombre es Saldina, y creo videos relacionados con TI y programación. Si eso te interesa, considera suscribirte a mi canal y darle a este video un pulgar hacia arriba. En este video en particular, quiero hablar sobre el polimorfismo.

El polimorfismo se refiere a la capacidad de un objeto para tener múltiples formas. Esto significa que puede tener dos o más objetos que heredan de la misma clase base. Estos objetos pueden tener un método con el mismo nombre pero diferentes implementaciones, lo que da como resultado diferentes comportamientos. Echemos un vistazo a un código que hemos escrito en mis cursos anteriores. He creado una clase llamada "YouTubeChannel" con propiedades privadas como el nombre, el número de suscriptores y los títulos de los videos publicados. También tiene una propiedad protegida llamada "nombre del propietario". Además, existen métodos públicos, un constructor, un método "getInfo" y métodos "suscribir/cancelar suscripción".

A continuación, tenemos un tipo específico de canal de YouTube llamado "CookingYouTubeChannel", que hereda de la clase base. Tiene su propio constructor y un método adicional llamado "práctica", que es específico para los canales de cocina. Ahora, quiero crear otra clase derivada llamada "SingersYouTubeChannel" para un canal de YouTube sobre canto. Esta clase también tiene un método de "práctica", pero la implementación es diferente del canal de cocina. Los cantantes practicaban el canto, aprendían nuevas canciones e incluso bailaban.

Para demostrar el polimorfismo, creo instancias de los canales de YouTube de la cocina y de los cantantes. Luego, invoco el método de "práctica" en cada canal. Puede ver que las respectivas implementaciones se llaman según el tipo de canal. Además, introduzco una propiedad "contentQuality" para rastrear la calidad del contenido. Cada vez que se invoca el método de "práctica", la calidad del contenido aumenta. También agrego un método llamado "checkAnalytics" que verifica la calificación de calidad del contenido y genera un mensaje basado en la calificación.

Para mostrar aún más el polimorfismo, uso punteros a la clase base para apuntar a objetos de clases derivadas. Asigno las direcciones de los canales de YouTube de la cocina y de los cantantes a estos punteros. Usando estos punteros, invoco el método "checkAnalytics" para cada canal, lo que demuestra que el polimorfismo nos permite usar punteros de clase base para llamar a métodos de clase derivados.

Espero que hayas encontrado este video agradable. Si lo hiciste, dale me gusta y considera suscribirte a mi canal. No olvides hacer clic en el ícono de la campana para recibir notificaciones de futuros videos. Gracias, y nos vemos en mi próximo video. ¡Adiós!

C++ OOP - What is polymorphism in programming? (simple example)
C++ OOP - What is polymorphism in programming? (simple example)
  • 2020.09.01
  • www.youtube.com
📚 Learn how to solve problems and build projects with these Free E-Books ⬇️C++ Lambdas e-book - free download here: https://bit.ly/freeCppE-BookEntire Objec...
 

Explicación de la relación entre funciones virtuales, funciones virtuales puras y clases abstractas en programación orientada a objetos



Explicación de la relación entre funciones virtuales, funciones virtuales puras y clases abstractas en programación orientada a objetos

En este video, explicaré el propósito y la relación entre funciones virtuales, funciones virtuales puras y clases abstractas. Estoy emocionado de continuar con esta lista de reproducción de programación orientada a objetos. Si tiene alguna pregunta o tema que le gustaría ver en videos futuros, deje un comentario a continuación. Ahora, profundicemos en las funciones virtuales.

Una función virtual es una función definida en una clase base y se puede redefinir en una clase derivada. El objetivo principal de las funciones virtuales es habilitar el polimorfismo en tiempo de ejecución. Cuando invoque una función virtual utilizando un puntero de clase base o una referencia, se ejecutará la versión más derivada de esa función. Si la clase derivada tiene su propia implementación, se ejecutará esa versión. De lo contrario, se utilizará la implementación en la clase base.

Veamos un ejemplo en Visual Studio. Crearemos una clase de "Instrumento" con una función virtual llamada "makeSound" que genera un mensaje. Luego, crearemos una clase derivada llamada "Acordeón" que anula la función "hacerSonido" con su propia implementación. Al usar un puntero de clase base para invocar la función, podemos ver que se ejecuta la versión derivada. Agregar la palabra clave "virtual" a la función de clase base garantiza que se llame a la versión más derivada.

A continuación, analicemos las funciones virtuales puras y las clases abstractas. Una función virtual pura es una función virtual sin implementación en la clase base. Obliga a las clases derivadas a proporcionar su propia implementación. Al establecer una función virtual en "igual a cero", creamos una función virtual pura. Esto convierte a la clase base en una clase abstracta, de la que no se puede crear una instancia. Las clases derivadas deben implementar la función virtual pura. Crearemos una clase "Piano" derivada de la clase "Instrumento". Si intentamos crear un objeto de tipo "Piano" sin implementar la función virtual pura, dará como resultado un error. Sin embargo, una vez que implementamos la función en la clase "Piano", podemos crear con éxito un objeto e invocar la función.

Finalmente, exploremos el comportamiento polimórfico de las funciones virtuales. Tenemos dos punteros de instrumentos, uno que apunta a un objeto "Acordeón" y el otro a un objeto "Piano". Mediante la creación de una matriz de punteros de instrumentos, podemos demostrar que invocar la función "makeSound" usando los punteros de la clase base da como resultado la ejecución de las versiones derivadas de la función.

Espero que esta explicación lo ayude a comprender mejor las funciones virtuales, las funciones virtuales puras y las clases abstractas. Si tiene más preguntas, hágamelo saber en los comentarios a continuación. ¡Gracias por mirar, y no olvides suscribirte!

Relationship between Virtual Functions, Pure Virtual Functions and Abstract Classes in OOP explained
Relationship between Virtual Functions, Pure Virtual Functions and Abstract Classes in OOP explained
  • 2021.04.15
  • www.youtube.com
📚 Learn how to solve problems and build projects with these Free E-Books ⬇️C++ Lambdas e-book - free download here: https://bit.ly/freeCppE-BookEntire Objec...
 

¡Abstracción explicada con ejemplos y código de la vida real! - Curso de programación orientada a objetos C++



¡Abstracción explicada con ejemplos y código de la vida real! - Curso de programación orientada a objetos C++

En este video, discutiré el importante concepto de abstracción en la programación orientada a objetos. Explicaré qué es la abstracción y demostraré cómo implementar y usar la abstracción en la programación de C++. Pero antes de profundizar, me gustaría presentar C++ Builder, un potente IDE que permite el desarrollo rápido de aplicaciones para múltiples plataformas con menos código. Se conecta a la perfección a varias bases de datos e incluye potentes bibliotecas como los marcos VCL y FireMonkey. Comienza gratis usando el enlace en la descripción.

La abstracción en la programación se refiere al acto de mostrar información importante mientras se ocultan detalles complejos y sin importancia. Para comprender mejor la abstracción, consideremos un ejemplo de la vida real: una máquina de café. Al usar una máquina de café, todo lo que necesita saber es cómo poner café y agua, y presionar un botón para hacer café. El proceso interno de la máquina es complejo, pero está abstraído y escondido detrás de un procedimiento simple. Esta abstracción facilita a los usuarios operar la máquina sin comprender su intrincado funcionamiento. De manera similar, en la programación, usamos la abstracción para ocultar detalles complejos y proporcionar una interfaz simplificada.

Otro aspecto clave de la abstracción es que los elementos abstraídos no cambian con frecuencia, o al menos no parecen cambiar para el usuario final. Esto significa que puede modificar la implementación interna, siempre que no cambie la interfaz expuesta al usuario. Por ejemplo, si una nueva empresa desarrolla una máquina de café más eficiente, puede cambiar los componentes internos para reducir el consumo de energía, hacer el café más rápido y reducir el ruido. Mientras el usuario aún necesite poner café y agua, y presione el botón, la interfaz sigue siendo la misma y el usuario no necesita aprender una nueva forma de operar la máquina. Esta estandarización del comportamiento a través de la abstracción permite que las nuevas empresas se basen en las expectativas de los usuarios existentes.

En programación, podemos crear capas de abstracción para ocultar detalles complejos y proporcionar una interfaz simplificada para otros desarrolladores. Por ejemplo, si creo una clase con varias funcionalidades complejas, puedo proporcionar una capa de abstracción que oculta la complejidad subyacente. Otros desarrolladores pueden utilizar la interfaz simple de la clase sin necesidad de conocer los detalles de implementación. En C++, logramos la abstracción usando clases abstractas, que contienen al menos una función virtual pura. Estas clases abstractas definen el contrato o interfaz que deben implementar otras clases.

Vamos a crear una clase abstracta llamada "Smartphone" para ilustrar esto. Declarará una función pública llamada "Toma una selfie", que sirve como una funcionalidad importante que todos los teléfonos inteligentes deberían tener. Al hacer de esta función una función virtual pura usando la sintaxis "= 0", transformamos la clase en una clase abstracta. No podemos crear instancias de clases abstractas directamente, pero podemos crear punteros a ellas. Cualquier clase que quiera ser un teléfono inteligente debe heredar de esta clase abstracta y proporcionar su propia implementación de la función virtual pura.

Por ejemplo, creemos una clase "Android" que herede de la clase "Smartphone". En esta clase, implementamos la función "Take a selfie" con la lógica compleja específica de los dispositivos Android. De manera similar, podemos crear una clase "iPhone" que también herede de "Smartphone" y proporcione su propia implementación de la función "Take a selfie". Cada clase puede tener su propia implementación única, pero desde la perspectiva de alguien que usa el teléfono inteligente, el proceso sigue siendo el mismo.

La abstracción lograda a través de la clase "Smartphone" permite a los desarrolladores que trabajan en clases de Android o iPhone centrarse en sus detalles de implementación específicos sin necesidad de conocer la lógica de la otra clase. Solo necesitan adherirse al contrato definido por la clase abstracta, asegurando que se implementen las funcionalidades requeridas. Al utilizar la abstracción, creamos una separación de preocupaciones, simplificamos el uso del código y facilitamos el desarrollo modular. La abstracción nos permite crear interfaces estandarizadas y ocultar implementaciones complejas, lo que resulta en más mantenimiento.

La abstracción nos permite crear interfaces estandarizadas y ocultar implementaciones complejas, lo que da como resultado un código más mantenible y flexible. Promueve la reutilización de código y el desarrollo modular al encapsular la funcionalidad en clases abstractas que pueden ser extendidas e implementadas por otras clases. Además de las clases abstractas, C++ también proporciona otro mecanismo de abstracción denominado interfaces. Las interfaces son clases puramente abstractas que definen un contrato de métodos que debe implementar cualquier clase que quiera adherirse a la interfaz. Esto permite una abstracción aún mayor y un acoplamiento débil entre los componentes.

En resumen, la abstracción en la programación orientada a objetos es el proceso de ocultar detalles complejos y proporcionar una interfaz simplificada. Permite a los desarrolladores centrarse en implementaciones específicas mientras abstraen la complejidad subyacente. Las clases e interfaces abstractas son las herramientas principales para lograr la abstracción en C++. Mediante el uso de la abstracción, podemos crear un código más modular, reutilizable y mantenible.

Abstraction explained with real-life examples and code! - C++ OOP Course
Abstraction explained with real-life examples and code! - C++ OOP Course
  • 2021.04.21
  • www.youtube.com
📚 Learn how to solve problems and build projects with these Free E-Books ⬇️C++ Lambdas e-book - free download here: https://bit.ly/freeCppE-BookEntire Objec...
 

Operador de C++ Sobrecarga de principiante a avanzado (explicación detallada)



Operador de C++ Sobrecarga de principiante a avanzado (explicación detallada)

Hola a todos y bienvenidos a mi canal. Estaba en medio de mi trabajo y no había planeado filmar este video, pero como estoy trabajando en un proyecto muy interesante, pensé ¿por qué no mostrárselo? Actualmente estoy trabajando en un gran proyecto con miles de archivos y millones de líneas de código. Estaba a punto de analizar mi código, lo que suele tardar entre 10 y 15 minutos en completarse. Entonces, mientras esperamos el análisis, les enseñaré sobre la sobrecarga de operadores.

El analizador que uso se llama PDS Studio, y puedes obtenerlo gratis usando el enlace en la descripción. Le mostraré cómo uso PDS Studio para encontrar errores y optimizar mi código. Una vez que descargue PDS Studio, necesita un código para analizar. Tengo la solución de mi trabajo, pero no puedo mostrarle el código debido a un acuerdo de confidencialidad. Sin embargo, les mostraré los resultados del análisis más adelante en el video.

Para analizar su código con PDS Studio, debe hacer clic en la pestaña Extensiones y seleccionar PDS Studio. Luego, elija la solución completa para el análisis. Dado que el análisis lleva algún tiempo, cambiaré a un proyecto vacío y, mientras tanto, le enseñaré sobre la sobrecarga de operadores.

La sobrecarga de operadores nos permite definir cómo se comporta un determinado operador con un tipo de datos específico. Por ejemplo, el operador más se comporta de manera diferente cuando se usa con números en comparación con cuando se usa con un tipo de datos definido por el usuario. Podemos crear funciones de operador para definir este comportamiento. Explicaré este concepto usando un ejemplo de cómo agregar dos tipos de datos definidos por el usuario.

En C++, podemos crear funciones de operador usando la palabra clave "operador" seguida del operador que queremos sobrecargar. Por ejemplo, podemos sobrecargar el operador más creando una función "operador+". Lo demostraré creando una estructura llamada "YouTubeChannel" con dos atributos: "name" y "subscribersCount". También crearemos un constructor para esta estructura.

Para sobrecargar el operador de inserción (<<) para nuestro tipo YouTubeChannel, necesitamos definir una función "operador<<". Esta función toma dos parámetros: un objeto de tipo "ostream" (por ejemplo, "cout") y un objeto de tipo "YouTubeChannel". Pasamos estos parámetros por referencia para evitar copias innecesarias.

Dentro de la función "operador<<", usamos el objeto "ostream" para mostrar la información sobre YouTubeChannel. En este caso, imprimimos el nombre y el número de suscriptores. Al sobrecargar el operador de inserción, habilitamos la impresión de objetos YouTubeChannel usando el comando "cout".

Para usar el operador de inserción sobrecargado, simplemente podemos escribir "cout << youtubeChannelObject". Esto funciona de manera similar a cómo imprimimos otros tipos usando "cout". También podemos invocar la función de operador directamente, como una función normal, pasando el objeto "cout" y el objeto YouTubeChannel como parámetros.

Tenga en cuenta que diferentes operadores tienen diferentes formas de sobrecarga. El operador de inserción se sobrecarga con la función "operador<<", pero otros operadores como más, menos, mayor que, menor que, igual a, etc., tienen sus propias funciones de operador específicas.

Eso es todo por este video. Espero que haya encontrado útil esta introducción a la sobrecarga de operadores. Consulte la descripción para obtener una lista de todos los operadores que se pueden sobrecargar en C++. Una vez que el análisis esté completo, te mostraré los resultados. Si tiene alguna pregunta, no dude en preguntar en los comentarios. ¡Gracias por ver!

C++ Operator Overloading beginner to advanced (in-depth explanation)
C++ Operator Overloading beginner to advanced (in-depth explanation)
  • 2021.06.30
  • www.youtube.com
📚 Learn how to solve problems and build projects with these Free E-Books ⬇️C++ Lambdas e-book - free download here: https://bit.ly/freeCppE-BookEntire Objec...