Метка: spl

Пример использования ArrayAccess

Мне недавно в блоге задали вопрос о применении ArrayAccess. Просто как замену массивам — глупо, тем более теряется производительность. Итак, для этого у нас две основные причины — set/get должны как-то влиять на значение переменных, вторая — объект может использовать данные помещённые в нём для других методов. Рассмотрим примеры. У нас есть класс для работы с таблице из базы данных как с объектом.

Читать далее »

SPL в PHP: ArrayObject

Довольно неожиданно пришла идея довести начатый шаблонизатор до юзабельного вида, дописал хелперы, встроил кеширование, решил прицепить хелпер для формы. И здесь мне стало нехватать ООП стиля. Накидав кой-чего понял что вначале нужно написать цикл статей о SPL (Стандартной PHP библиотеке). Эта штука очень полезна при ООП стиле кодирования, а особо нормальных статей об SPL на русском я не обнаружил. Начнёмс. ArrayObject — предназначен для того, чтобы объект вёл себя как массив, даёт доступ к данным через квадратные скобки и позволяет делать foreach ArrayObject implements IteratorAggregate , Traversable , ArrayAccess , Countable { /* Methods */ ArrayObject::__construct ( mixed $input ) void ArrayObject::append ( mixed $newval ) int ArrayObject::count ( void ) ArrayIterator ArrayObject::getIterator ( void ) bool ArrayObject::offsetExists ( mixed $index ) mixed ArrayObject::offsetGet ( mixed $index ) void ArrayObject::offsetSet ( mixed $index , mixed $newval ) void ArrayObject::offsetUnset ( mixed $index ) } Данный класс имплементирует интерфейсы IteratorAggregate , Traversable , ArrayAccess , Countable IteratorAggregate , Traversable — отвечают за гуляние по объекту, соответственно нужно реализовать метод getIterator. Эти вещи будем разбирать в другой раз. Countable — нужно реализовать интерфейс для получения размера count. ArrayAccess — это  квадратные скобочки — проверка существования offsetExists, получение значения — offsetGet, присвоение значения — offsetSet, уничтожение элемента — offsetUnset и добавление элемента — append. Со скучной теорией покончено, сейчас практика class Amdy_Array extends ArrayObject { protected $array; public function __construct($array) { $this->array = $array; } public function append($value) { $this->array[] = $value; } function offsetSet($key, $value) { if ($key) { $this->array[$key] = $value; } else { $this->array[] = $value; } } function offsetGet($key) { if ( array_key_exists($key, $this->array) ) { return $this->array[$key]; } } function offsetUnset($key) { if ( array_key_exists($key, $this->array) ) { unset($this->array[$key]); } } function offsetExists($offset) { return array_key_exists($offset, $this->array); } public function dump() { var_dump($this->array); } } Так мы побыстрому создали свой обработчик, унаследовав класс из SPL. Что же там происходит. В конструктор передаётся сам массив, его можно передать и позже, но не важно. Данный массив мы загоняем во внутреннюю переменную $this->array, дальше, мы описываем,  как должны обрабатываться запросы к объекту как к массиву. Т.е. все запросы будут реально относиться в переменно $this->array. Можно и вовсе не заводить эту переменную, а работать с атрибутами класса, если в коде заменить $this->array, на get_class_vars($this), $this->{$k} и т.д. Простой пример использования. $array = new Amdy_Array( array( ‘test’, ‘test1’ => array(0,1,2,3), 2, ‘test4’ => ‘test2 value’ ) ); $array[] = ‘test2222’; echo $array[0] . ‘<hr/>’; echo $array[‘test4’] . ‘<hr/>’; $array->dump(); PHP не стоит на месте, потому, кое-что уже изменилось, постоянно добавляются новые классы, методы и интерфейсы, чтобы не изобретать свои велосипеды.

Читать далее »