PHP 8.4.1 Released!

Класс CallbackFilterIterator

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

Введение

Обзор класса

class CallbackFilterIterator extends FilterIterator {
/* Методы */
public __construct(Iterator $iterator, callable $callback)
public accept(): bool
/* Наследуемые методы */
}

Примеры

Callback-функция может принимать до трёх аргументов: текущий элемент, текущий ключ и итератор соответственно.

Пример #1 Доступные аргументы обратного вызова

<?php

/**
* Callback-функция для CallbackFilterIterator
*
* @param $current Значение текущего элемента
* @param $key Ключ текущего элемента
* @param $iterator Фильтруемый итератор
* @return boolean TRUE для принятия текущего элемента, иначе - FALSE
*/
function my_callback($current, $key, $iterator) {
// Код фильтрации
}

?>

Любая callback-функция типа callable может быть использована. Например, строка, содержащая имя функции, массив для метода или анонимная функция.

Пример #2 Основные примеры обратного вызова

<?php

$dir
= new FilesystemIterator(__DIR__);

// Фильтр больших файлов ( > 100MB)
function is_large_file($current) {
return
$current->isFile() && $current->getSize() > 104857600;
}
$large_files = new CallbackFilterIterator($dir, 'is_large_file');

// Фильтр каталогов
$files = new CallbackFilterIterator($dir, function ($current, $key, $iterator) {
return
$current->isDir() && ! $iterator->isDot();
});

?>

Содержание

  • CallbackFilterIterator::accept — Вызывает callback-функцию и передаёт ей в качестве аргументов текущее значение, текущий ключ и внутренний указатель
  • CallbackFilterIterator::__construct — Создаёт фильтрующий итератор на основе другого итератора
Добавить

Примечания пользователей 3 notes

up
10
dave1010 at gmail dot com
12 years ago
Implementation for PHP < 5.4:

<?php
if (!class_exists('CallbackFilterIterator')) {
class
CallbackFilterIterator extends FilterIterator {
protected
$callback;

// "Closure" type hint should be "callable" in PHP 5.4
public function __construct(Iterator $iterator, Closure $callback = null) {
$this->callback = $callback;
parent::__construct($iterator);
}

public function
accept() {
return
call_user_func(
$this->callback,
$this->current(),
$this->key(),
$this->getInnerIterator()
);
}
}
}

?>
up
2
asadi dot jabar at outlook dot com
6 years ago
CallbackFilterIterator class didnot implement OuterIterator interface directly

below is the correct hierarchy

CallbackFilterIterator
|__FilterIterator
|___ IteratorIterator
|____ OuterIterator

please fix the documentation
up
1
tunaabutbul[plus]php[at]gmail[dot]com
7 years ago
i PHP 7 you can use Anonymous classes to get the same results.

<?php

class MyIterator implements Iterator
{
/**
* @var \Iterator
*/
protected $next;

/**
* Collection constructor.
*
* @param \Iterator $next
*/
public function __construct(Iterator $next)
{
$this->next = $next;
}

/**
* @param callable $callback
*
* @return static
*/
public function filter(callable $callback = null)
{
return new static(new class(
$this, $callback) extends FilterIterator
{
protected
$callback;

public function
__construct(\Iterator $iterator, callable $callback = null)
{
parent::__construct($iterator);

$this->callback = $callback ?: function($current) {
return ! empty(
$current);
};;
}

public function
accept()
{
return
call_user_func($this->callback, parent::accept());
}
});
}
// Iterator methods ...
}
// .......
?>
To Top