Ds\Vector::reduce

(PECL ds >= 1.0.0)

Ds\Vector::reduceReduz o vetor a um único valor usando uma função de callback

Descrição

public Ds\Vector::reduce(callable $callback, mixed $initial = ?): mixed

Reduz o vetor a um único valor usando uma função de callback.

Parâmetros

callback
callback(mixed $carry, mixed $value): mixed
carry

O valor de retorno da callback anterior, ou initial se for a primeira iteração.

value

O valor da iteração atual.

initial

O valor inicial do valor de transporte. Pode ser null.

Valor Retornado

O valor de retorno da callback final.

Exemplos

Example #1 Exemplo deDs\Vector::reduce() com um valor inicial

<?php
$vector = new \Ds\Vector([1, 2, 3]);

$callback = function($carry, $value) {
    return $carry * $value;
};

var_dump($vector->reduce($callback, 5));

// Iterações:
//
// $carry = $initial = 5
//
// $carry = $carry * 1 =  5
// $carry = $carry * 2 = 10
// $carry = $carry * 3 = 30
?>

O exemplo acima produzirá algo semelhante a:

int(30)

Example #2 Exemplo de Ds\Vector::reduce() sem um valor inicial

<?php
$vector = new \Ds\Vector([1, 2, 3]);

var_dump($vector->reduce(function($carry, $value) {
    return $carry + $value + 5;
}));

// Iterações:
//
// $carry = $initial = null
//
// $carry = $carry + 1 + 5 =  6
// $carry = $carry + 2 + 5 = 13
// $carry = $carry + 3 + 5 = 21
?>

O exemplo acima produzirá algo semelhante a:

int(21)