ArrayObject::__construct
(PHP 5 >= 5.0.0, PHP 7)
ArrayObject::__construct — Создает новый объект типа массив
Описание
public ArrayObject::__construct
([ mixed
$input
= []
[, int $flags
= 0
[, string $iterator_class
= "ArrayIterator"
]]] )Создает новый объект типа массив (object).
Список параметров
-
input
-
flags
-
Флаги для контролирования поведения объекта ArrayObject. Смотрите ArrayObject::setFlags().
-
iterator_class
-
Указывает класс, который будет использоваться в качестве итератора объекта ArrayObject.
Возвращаемые значения
Возвращает ArrayObject при успешном выполнении.
Ошибки
Выбрасывает InvalidArgumentException в случае если:
-
input
не является массивом или объектом -
flags
не является целым числом -
iterator_class
не является объектом, который имплементирует Iterator
Примеры
Пример #1 Пример использования ArrayObject::__construct()
<?php
$array = array('1' => 'one',
'2' => 'two',
'3' => 'three');
$arrayobject = new ArrayObject($array);
var_dump($arrayobject);
?>
Результат выполнения данного примера:
object(ArrayObject)#1 (3) { [1]=> string(3) "one" [2]=> string(3) "two" [3]=> string(5) "three" }
- PHP Руководство
- Функции по категориям
- Индекс функций
- Справочник функций
- Другие базовые расширения
- Стандартная библиотека PHP (SPL)
- Различные Классы и Интерфейсы
- Функция ArrayObject::append() - Добавляет значение в конец массива
- Функция ArrayObject::asort() - Сортирует записи по значению
- Функция ArrayObject::__construct() - Создает новый объект типа массив
- Функция ArrayObject::count() - Возвращает количество публичных свойств ArrayObject
- Функция ArrayObject::exchangeArray() - Заменяет текущий массив на другой
- Функция ArrayObject::getArrayCopy() - Создаёт копию ArrayObject
- Функция ArrayObject::getFlags() - Получает флаги поведения
- Функция ArrayObject::getIterator() - Создаёт новый итератор из экземпляра ArrayObject
- Функция ArrayObject::getIteratorClass() - Возвращает имя класса итератора для ArrayObject
- Функция ArrayObject::ksort() - Сортирует записи по ключам
- Функция ArrayObject::natcasesort() - Сортирует массив, используя регистронезависимый алгоритм "natural order"
- Функция ArrayObject::natsort() - Сортирует массив, используя алгоритм "natural order"
- Функция ArrayObject::offsetExists() - Проверяет, существует ли указанный индекс
- Функция ArrayObject::offsetGet() - Возвращает значение по указанному индексу
- Функция ArrayObject::offsetSet() - Установливает новое значение по указанному индексу
- Функция ArrayObject::offsetUnset() - Удаляет значение по указанному индексу
- Функция ArrayObject::serialize() - Сериализует ArrayObject
- Функция ArrayObject::setFlags() - Устанавливает флаги поведения
- Функция ArrayObject::setIteratorClass() - Устанавливает имя класса итератора для ArrayObject
- Функция ArrayObject::uasort() - Сортирует записи, используя пользовательскую функцию для сравнения элементов и сохраняя при этом связь ключ/значение
- Функция ArrayObject::uksort() - Сортирует массив по ключам, используя пользовательскую функцию для сравнения
- Функция ArrayObject::unserialize() - Десериализует ArrayObject
Коментарии
As Marcus explained, the flag ArrayObject::SPL_ARRAY_AS_PROPS means the array element may be used as a property if there is no conflict with visible properties.
If there are visible properties in the class, the array element will not overwrite it's value.
<?php
class Rules extends ArrayObject {
public $len = 1;
function __construct($array){
parent::__construct($array,ArrayObject::ARRAY_AS_PROPS);
$this['len'] = 2;
}
}
$x = new Rules(array(1,2));
echo $x->len;
?>
Result: 1
<?php
class Rules extends ArrayObject {
private $len = 1;
function __construct($array){
parent::__construct($array,ArrayObject::ARRAY_AS_PROPS);
$this['len'] = 2;
}
}
$x = new Rules(array(1,2));
echo $x->len;
?>
Result: 2
Note that the first argument to ArrayObject::__construct, the initial array, is passed by reference. Nevertheless, modification of the array doesn't modify the object, so it may cause unexpected behaviour.
<?php
$array = array('foo' => 'initial');
$obj = new ArrayObject($array);
// array was passed by reference:
$obj['foo'] = 'modified';
var_dump($array); // foo => modified
// but it doesn't work backwards:
$array['foo'] = 'modified_again';
var_dump($obj); // foo => modified
var_dump($array); // foo => modified_again
?>
BTW, if you need to change array later, use exchangeArray() method. Good to know when you are writing a class that extends ArrayObject()
AFAIK, exchangeArray() doesn't return anything.
<?php
$a = array('one', 'two', 'three');
$ao = new ArrayObject($a);
foreach ($ao as $element) {
echo $element . ' '; // one two three
}
$b = array('four', 'five', 'six');
$ao->exchangeArray($b); // returns null
foreach ($ao as $element) {
echo $element . ' '; // four five six
}
?>
The great confusion with this class is in its naming. ArrayObject infers it will behave as an Array and as an Object. It won't. It behaves as an array. It would better be called ArrayType. You can, with some work, get it to work both as an object and as an array, but that is up to you.