The Serializable interface

(PHP 5 >= 5.1.0, PHP 7, PHP 8)

Introdução

Interface para serialização personalizada.

Classes que implementam esta intarface não possuem mais suporte aos métodos __sleep() and __wakeup(). O método serialize é chamado não importando se uma instância possui a necessidade de ser serializada. Não invoca o método __destruct(), ou possui qualquer outro efeito colateral a não ser que programado no método. Quando os dados são deserializados, a classe toma conhecimento e o método unserialize() apropriado é chamado como um construtor, em vez de chamar o método __construct(). Se necessitar executar o construtor padrão, pode-se fazer no método.

Aviso

A partir do PHP 8.1.0, uma classe que implemente Serializable sem implementar __serialize() e __unserialize() gerará um aviso de descontinuação.

Resumo da Interface

interfaceSerializable {
publicunserialize(string$data): void
}

Exemplos

Exemplo #1 Basic usage

<?php
class obj implements Serializable {
private
$data;
public function
__construct() {
$this->data = "My private data";
}
public function
serialize() {
return
serialize($this->data);
}
public function
unserialize($data) {
$this->data = unserialize($data);
}
public function
getData() {
return
$this->data;
}
}

$obj = new obj;
$ser = serialize($obj);

var_dump($ser);

$newobj = unserialize($ser);

var_dump($newobj->getData());
?>

O exemplo acima produzirá algo semelhante a:

 string(38) "C:3:"obj":23:{s:15:"My private data";}" string(15) "My private data" 

Índice

To Top