> 웹 프론트엔드 > JS 튜토리얼 > 객체 지향 프로그래밍 - 현실의 추상화

객체 지향 프로그래밍 - 현실의 추상화

王林
풀어 주다: 2024-08-08 11:30:22
원래의
1165명이 탐색했습니다.

Programación Orientada a Objetos - Una abstracción de la realidad

안녕하세요. 튜토리얼처럼 보이는 이번 글에서는 특히 처음에 제가 많이 고민했던 주제에 대해 다루겠습니다. 그러나 이러한 어려움으로 인해 나는 일상 생활의 추상화를 내 자신의 것으로 만들고 코드 라인, 유형의 표현을 가져오기 위해 연구하고 연구하고 공부하게 되었습니다(저를 믿으십시오. 이것은 때때로 엄청난 작업이 될 수 있습니다). 나는 주제에 대해 너무 열정적이어서 이제 이 기사에서 그것을 이해하는 데 중요한 데이터를 공유하므로 문제의 핵심으로 들어가겠습니다.

저는 가능한 최선의 방법인 객체지향 프로그래밍이나 JavaScript를 제가 선택한 언어로 사용하여 약어(OOP)로 설명하거나 시도할 것입니다. OOP를 실제 상황에 적용하는 방법을 이해하려면 객체 지향 프로그래밍이 단순한 기술이 아니라 삶에 대한 접근 방식이라는 점을 내면화해야 합니다! 이 기사에서는 기본적인 OOP 개념을 살펴보고 이를 일상 생활의 실제 사례에 적용해 보겠습니다.

객체 지향 프로그래밍이란 무엇입니까?

객체 지향 프로그래밍은 "객체" 개념을 기반으로 하는 프로그래밍 패러다임으로, 말 그대로 삶의 객체인 사과, 개, 집, 자동차, 고무 아빠. 이제 이러한 객체가 속성이나 특성, 기능의 형태로 데이터를 포함할 수 있다는 점, 즉 객체가 작업을 수행할 수 있다는 점을 시각화해 보세요. 각 개체가 고유한 특성을 지닌 독립적 개체로 표현될 수 있는 가상 세계를 모델링한다고 상상해 보세요.

실제 생활과 OOP의 객체

OOP를 더 잘 이해하기 위해 실제 사례인 자동차를 살펴보겠습니다. 자동차에는 모델, 색상, 속도와 같은 속성뿐만 아니라 출발 및 정지와 같은 방법도 있을 수 있습니다. 이것을 OOP의 세계로 옮기는 것은 매우 간단합니다:

class Auto {
  constructor(modelo, color) {
    this.modelo = modelo;
    this.color = color;
    this.velocidad = 0;
  }

  arrancar() {
    console.log(`El auto ${this.modelo} ha arrancado.`);
  }

  detener() {
    console.log(`El auto ${this.modelo} se ha detenido.`);
    this.velocidad = 0;
  }

  acelerar(kmh) {
    this.velocidad += kmh;
    console.log(`El auto ${this.modelo} acelera a ${this.velocidad} km/h.`);
  }
}

// Crear un objeto auto
const miAuto = new Auto('Sedán', 'Rojo');

// Utilizar métodos del objeto auto
miAuto.arrancar();
miAuto.acelerar(50);
miAuto.detener();
로그인 후 복사

이 예에서는 모델, 색상, 속도 등의 속성과 메서드, 즉 시작, 중지, 가속 등 수행할 수 있는 작업을 포함하는 Auto 클래스를 만들었습니다. 그런 다음 이 클래스를 기반으로 myAuto 객체를 생성하고 이를 사용하여 실제 동작을 시뮬레이션합니다.

상속: 계층 구조의 핵심

이제 자동차뿐만 아니라 오토바이도 모델링하고 싶다고 상상해 보세요. 둘 다 몇 가지 유사점을 공유하지만 독특한 특징도 있습니다. 이것이 바로 OOP의 상속 개념이 적용되는 부분입니다.

class Camioneta extends Auto {
  constructor(modelo, color, tipo) {
    super(modelo, color);
    this.tipo = tipo;
  }

  realizarTruco() {
    console.log(`La camioneta ${this.modelo} ${this.tipo} realiza un asombroso truco.`);
  }
}

// Crear un objeto camioneta
const miCamioneta = new Camioneta('Explorer', 'Negra', '4x4');

// Utilizar métodos del objeto camioneta
miCamioneta.arrancar();
miCamioneta.acelerar(80);
miCamioneta.realizarTruco();
miCamioneta.detener();
로그인 후 복사

여기서는 Car 클래스를 확장하는 새로운 Truck 클래스를 만들었습니다. extends 키워드를 사용하면 상위 클래스(Auto)의 모든 속성과 메서드를 상속받을 수 있습니다. 또한 하위 클래스(Pickup)에는 추가 속성과 메서드가 있을 수 있습니다.

캡슐화: 비밀 보호

캡슐화는 객체의 내부 세부정보를 보호하고 필요한 것만 노출할 수 있게 해주는 OOP의 또 다른 핵심입니다. "은행 계좌"를 사용한 간단한 예를 살펴보겠습니다.

class CuentaBancaria {
  constructor(titular, saldoInicial) {
    this.titular = titular;
    this._saldo = saldoInicial; // El saldo se designa con el prefijo _ para indicar que es privado
  }

  get saldo() {
    return this._saldo;
  }

  depositar(cantidad) {
    if (cantidad > 0) {
      this._saldo += cantidad;
      console.log(`${cantidad} depositados. Nuevo saldo: ${this._saldo}`);
    } else {
      console.log("Error: La cantidad debe ser mayor que cero.");
    }
  }

  retirar(cantidad) {
    if (cantidad > 0 && cantidad <= this._saldo) {
      this._saldo -= cantidad;
      console.log(`${cantidad} retirados. Nuevo saldo: ${this._saldo}`);
    } else {
      console.log("Error: Cantidad inválida o saldo insuficiente.");
    }
  }
}

// Crear una cuenta bancaria
const miCuenta = new CuentaBancaria('Juan Pérez', 1000);

// Utilizar métodos del objeto cuenta bancaria
console.log(`Saldo inicial: ${miCuenta.saldo}`);
miCuenta.depositar(500);
miCuenta.retirar(200);

로그인 후 복사

이 예에서는 get 메소드를 사용하여 계정 잔액에 액세스하여 캡슐화했습니다. 이는 수업 외부에서 잔액이 직접 수정되는 것을 방지하여 은행 계좌의 무결성을 유지합니다.

다형성: 다재다능함의 마법

다형성을 사용하면 서로 다른 클래스가 동일한 메서드 이름을 공유하지만 각 클래스마다 특정 동작을 공유할 수 있습니다. 이를 설명하기 위해 소리를 내는 동물이 있는 동물원을 상상해 보겠습니다.

class Animal {
  hacerSonido() {
    console.log('Algunos sonidos genéricos de animal.');
  }
}

class Perro extends Animal {
  hacerSonido() {
    console.log('¡Guau! ¡Guau!');
  }
}

class Gato extends Animal {
  hacerSonido() {
    console.log('¡Miau! ¡Miau!');
  }
}

// Crear objetos animales
const miAnimal = new Animal();
const miPerro = new Perro();
const miGato = new Gato();

// Utilizar el método hacerSonido de cada objeto
miAnimal.hacerSonido();
miPerro.hacerSonido();
miGato.hacerSonido();

로그인 후 복사

이 예에서 Dog 및 Cat 클래스는 Animal 클래스에서 상속되지만 각각 고유한 구현으로 makeSound 메서드를 재정의합니다. 이를 통해 다양한 종류의 동물이 동일한 방법을 다르게 사용할 수 있습니다.

결론: OOP... 실행해 보세요

이 지점에 도달해주셔서 정말 감사드립니다! 우리는 객체, 상속, 캡슐화, 다형성과 같은 핵심 개념을 탐구하고 이를 실제 상황에 적용했습니다. OOP는 세상을 더 효과적으로 모델링하고 이해하고 코드에 적용할 수 있는 사고 방식이라는 점을 기억하세요.

그러므로 다음에 자동차, 은행 계좌, 애완동물을 보게 되면 코드에서 이를 객체로 어떻게 표현할 수 있는지 생각해 보세요. 객체 지향 프로그래밍은 강력한 도구일 뿐만 아니라 프로그램에 생명을 불어넣는 방법이기도 합니다!

이 기사가 도움이 되셨기를 바라며 프로젝트에 활용하시기 바랍니다. 귀하의 생각과 다른 실제 추상화가 있는지 알려주려면 의견을 남겨주세요. ;)

위 내용은 객체 지향 프로그래밍 - 현실의 추상화의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:dev.to
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿