Решение зависит от версии PHP, которую вы используете. По крайней мере, есть 2 решения:
Первый (более новые версии PHP)
Как сказал @JosepAlsina, лучшее и самое короткое решение - использовать array_column
следующее:
$catIds = array_column($objects, 'id');
Примечание:
повторять итерацию array
содержащего \stdClass
es, используемого в вопросе, можно только с версиями PHP >= 7.0
. Но при использовании array
содержащего array
s вы можете сделать то же самое, начиная с PHP >= 5.5
.
Второй (более старые версии PHP)
@Greg сказал, что в более старых версиях PHP можно сделать следующее:
$catIds = array_map(create_function('$o', 'return $o->id;'), $objects);
Но будьте осторожны: в новых версиях PHP >= 5.3.0
лучше использовать Closure
s, например:
$catIds = array_map(function($o) { return $o->id; }, $objects);
Различия
Первое решение создает новую функцию и помещает ее в вашу оперативную память. Сборщик мусора по какой-то причине не удаляет уже созданный и уже вызванный экземпляр функции из памяти. И это независимо от того, что созданный экземпляр функции никогда не может быть вызван снова, потому что у нас нет указателя на него. И при следующем вызове этого кода та же функция будет создана снова. Такое поведение медленно заполняет вашу память ...
Оба примера с выводом в память для сравнения:
ПЛОХОЙ
while (true)
{
$objects = array_map(create_function('$o', 'return $o->id;'), $objects);
echo memory_get_usage() . "\n";
sleep(1);
}
// the output
4235616
4236600
4237560
4238520
...
ХОРОШО
while (true)
{
$objects = array_map(function($o) { return $o->id; }, $objects);
echo memory_get_usage() . "\n";
sleep(1);
}
// the output
4235136
4235168
4235168
4235168
...
Это также можно обсудить здесь
Утечка памяти?! Правильно ли работает сборщик мусора при использовании create_function внутри array_map?