3v4l.org

run code in 300+ PHP versions simultaneously
<?php final class SensitiveValue implements \Serializable { private $value; /** * @param mixed $value */ final public function __construct($value) { $this->value = $value; } /** * @return mixed */ public function peek() { return $this->value; } /** * @return mixed */ public function get() { $value = $this->value; $this->erase(); return $value; } public function erase() { $this->value = null; } /** * {@inheritDoc} */ public function serialize() { return; } /** * {@inheritDoc} */ public function unserialize($serialized) { } /** * {@inheritDoc} */ public function __toString() { return ''; } /** * {@inheritDoc} */ public function __clone() { throw new \Exception('It is not permitted to clone this object.'); } } $value = new SensitiveValue(new \DateTime()); $time = $value->get(); echo $value->get()->format('Y-m-d');
Output for git.master, git.master_jit, rfc.property-hooks
Deprecated: SensitiveValue implements the Serializable interface, which is deprecated. Implement __serialize() and __unserialize() instead (or in addition, if support for old PHP versions is necessary) in /in/Yk7kd on line 3 Fatal error: Uncaught Error: Call to a member function format() on null in /in/Yk7kd:65 Stack trace: #0 {main} thrown in /in/Yk7kd on line 65
Process exited with code 255.

This tab shows result from various feature-branches currently under review by the php developers. Contact me to have additional branches featured.

Active branches

Archived branches

Once feature-branches are merged or declined, they are no longer available. Their functionality (when merged) can be viewed from the main output page


preferences:
42.81 ms | 401 KiB | 8 Q