Pular para o conteúdo principal

PHP - Herança e polimorfismo

Neste post, vamos mostrar como usar herança e polimorfismo em PHP, incluindo exemplos práticos (você pode ver o que já publicamos sobre o PHP aqui).


Esses dois elementos que iremos tratar hoje dizem respeito a base do paradigma de orientação a objetos, entende-los é fundamental para criar boas aplicações com recursos reutilizáveis e também compreender recursos e complementos externos a nossa aplicação, sejam das linguagens de programação com as quais estamos lidando como também o uso de plugins e extensões de terceiros.


Herança em PHP

A herança é um mecanismo que permite que uma classe herde as propriedades e métodos de outra classe. Isso permite a reutilização de código e a organização hierárquica de classes. Por exemplo, a seguinte classe "Estudante" herda da classe "Pessoa" e adiciona a propriedade "matricula":

    
        class Estudante extends Pessoa {
            public $matricula;
        }            
    

Polimorfismo em PHP

O polimorfismo é um mecanismo que permite que objetos de classes diferentes sejam tratados de forma genérica. Isso é possível através da implementação de interfaces, que definem um conjunto comum de métodos que devem ser implementados pelas classes que as implementam. Por exemplo, a seguinte interface "Veiculo" define o método "mover":

    
        interface Veiculo {
            public function mover();
        }
    

E a classe Automovel implementa essa interface e define o método mover de forma específica.

    
        class Automovel implements Veiculo{
            public $marca;
            public $modelo;
            public $ano;
            private $ligado = false;
            
            public function __construct($marca, $modelo, $ano) {
                $this->marca = $marca;
                $this->modelo = $modelo;
                $this->ano = $ano;
            }
            
            public function mover(){
                if($this->ligado){
                    echo "O carro está se movendo";
                }else{
                    echo "Ligue o carro antes de movê-lo";
                }
            }
            
            public function ligar() {
                $this->ligado = true;
            }
            public function desligar() {
                $this->ligado = false;
            }
            public function mostrarDados() {
                echo "Marca: " . $this->marca . "\n";
            }
        }
    

Dessa forma, é possível tratar objetos de diferentes classes como objetos de uma classe genérica, e chamar o método "mover" de forma genérica, independente da classe específica do objeto.


Conclusão

Juntos, herança e polimorfismo permitem a construção de sistemas orientados a objetos mais flexíveis e reutilizáveis, poupando tempo na compreensão e manutenção das funcionalidades.

Comentários

Mais visitadas

Aplicação Flask usando Nginx e Gunicorn

Aplicação Flask usando Nginx e Gunicorn Se você já desenvolveu uma aplicação Flask básica, sabe que o servidor de desenvolvimento embutido não é ideal para produção. Ele não é projetado para lidar com altos volumes de tráfego ou conexões simultâneas. Para tornar sua aplicação Flask mais robusta e pronta para produção, podemos usar o Gunicorn como servidor de aplicação e o Nginx como proxy reverso. Neste artigo, vamos adaptar o exemplo anterior ( Criando uma Aplicação CRUD com Flask, PostgreSQL e Docker ) para incluir o Nginx e o Gunicorn. O que são Nginx e Gunicorn? Gunicorn O Gunicorn (Green Unicorn) é um servidor de aplicação WSGI que roda aplicações Python como o Flask. Ele é eficiente e simples de configurar, lidando com múltiplas requisições ao mesmo tempo, algo que o servidor embutido do Flask não faz bem. Nginx O Nginx é um servidor web que atua como um proxy reverso. Ele recebe requisições HTTP e as encaminha ao Gunicorn. Além disso, o Nginx pode: Servir arquivos ...

Alterar cores do PageControl (Delphi)

O padrão Windows todo cinza não é muito atraente, por isso quando nos utilizarmos do PageControl podemos alterar suas cores e fontes da seguinte maneira: Em primeiro lugar devemos alterar a propriedade OwnerDraw para TRUE ; Depois implementar seu método DrawTab da seguinte maneira: //pinta a fonte Control.Canvas.Font.Color:=clBlack; // // pinta a paleta / aba Control.Canvas.brush.Color:=clSkyBlue; PageControl1.Canvas.Rectangle(Rect); Control.Canvas.TextOut(Rect.left+5,Rect.top+3,PageControl1.Pages[tabindex].Caption); // pinta a parte interna (tabsheet) PageControl1.Pages[TabIndex].brush.Color := Control.Canvas.brush.Color; PageControl1.Pages[TabIndex].Repaint; Caso a intenção seja manter cada aba com seu próprio estilo basta adicionar um CASE filtrando o índice das abas: case TabIndex of   0: Control.Canvas.Font.Color:=clBlack;   1: Control.Canvas.Font.Color:=clWindow; ...

Centralizar Texto em Edit

Como todos sabemos o Edit mantém todo texto digitado a esquerda, o que não fica bem quando o usamos para a entrada de números, pois bem, o exemplo abaixo apresenta uma alternativa para centralizar um determinado valor dentro de um Edit: procedure EditChange(Sender: TObject); var vl_label : TLabel; //variável do tipo Label begin vl_label := TLabel.Create(self); //criamos um label WITH vl_label DO BEGIN Font.Name := TEdit(sender).Font.Name; //pegamos a fonte usada no edit Caption := TEdit(sender).Text; //pegamos o conteúdo do edit SendMessage(TEdit(sender).Handle, EM_SETMARGINS, EC_LEFTMARGIN, (TEdit(sender).Width-vl_label.Width) div 2); //centraliza no label e retorna para o edit END ; vl_label.Free; end ;