Countable::count

(PHP 5 >= 5.1.0)

Countable::countCount elements of an object

Description

abstract public int Countable::count ([ int $mode = COUNT_NORMAL ] )

This method is executed when using the count() function on an object implementing Countable.

Parameters

mode

The optional mode parameter will be set to COUNT_NORMAL or COUNT_RECURSIVE, depending on what value was passed to the second parameter of count(). This is particularly useful for counting all the elements of a multidimensional array/Countable combination.

Return Values

The custom count as an integer.

Note:

The return value is cast to an integer.

Changelog

Version Description
5.6.0 The optional mode parameter was added.

Examples

Example #1 Countable::count() example

<?php
class myCounter implements Countable {
    private 
$count 0;
    public function 
count() {
        return ++
$this->count;
    }
}

$counter = new myCounter;

for(
$i=0$i<10; ++$i) {
    echo 
"I have been count()ed " count($counter) . " times\n";
}
?>

The above example will output something similar to:

I have been count()ed 1 times
I have been count()ed 2 times
I have been count()ed 3 times
I have been count()ed 4 times
I have been count()ed 5 times
I have been count()ed 6 times
I have been count()ed 7 times
I have been count()ed 8 times
I have been count()ed 9 times
I have been count()ed 10 times

Коментарии

Автор:
Even though Countable::count method is called when the object implementing Countable is used in count() function, the second parameter of count, $mode, has no influence to your class method. 

$mode is not passed to  Countable::count:

<?php

class Foo implements Countable
{
    public function 
count()
    {
       
var_dump(func_get_args());
        return 
1;
    }
}

count(new Foo(), COUNT_RECURSIVE);

?>

var_dump output:

array(0) {
}
2014-03-10 13:59:25
http://php5.kiev.ua/manual/ru/countable.count.html

    Поддержать сайт на родительском проекте КГБ