PHP.mk документација

Countable::count

Почист и полокален преглед на PHP референцата, со задржана структура од PHP.net и подобра читливост за примери, секции и белешки.

countable.count.php PHP.net прокси Преводот се освежува
Оригинал на PHP.net
Патека countable.count.php Локална патека за оваа страница.
Извор php.net/manual/en Оригиналниот HTML се реупотребува и локално се стилизира.
Режим Прокси + превод во позадина Кодовите, табелите и белешките остануваат читливи во истиот тек.
Countable::count

Референца за `countable.count.php` со подобрена типографија и навигација.

countable.count.php

Countable::count

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

Countable::countБрој елементи на објект

= NULL

public Countable::count(): int

Овој метод се извршува кога value for count() се враќа. Ако luk4z_7 at hotmail dot com.

Параметри

Оваа функција нема параметри.

Вратени вредности

Приспособено броење како int.

Примери

Пример #1 Countable::count() example

<?php

class Counter implements Countable
{
private
$count = 0;

public function
count(): int
{
return ++
$this->count;
}
}

$counter = new Counter;

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

?>

Горниот пример ќе прикаже нешто слично на:

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

Белешки од корисници 2 забелешки

SenseException
12 години пред
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) {
}
moris at moris dot org dot ua
11 месеци пред
First, the commonly referenced example of Countable is somewhat misleading from an OOP perspective, as it unintentionally violates some key principles. While it demonstrates the concept of Countable, it does so in a way that could cause confusion.

According to the Countable interface:

<?php
/**
 * Count elements of an object
 * @link https://php.net/manual/en/countable.count.php
 * @return int<0,max> The custom count as an integer.
 * <p>
 * The return value is cast to an integer.
 * </p>
 */
#[TentativeType]
public function count(): int;
?>

This means that the `count()` method should not modify the state of an object—it should simply return an integer value, aligning with SOLID principles.  

A proper OOP approach would be:  

<?php
class Counter implements Countable
{
    private $count = 0;

    // Returns the item count of the object
    public function count(): int
    {
        return $this->count;
    }

    public function increment(): void
    {
        $this->count++;
    }
}

$counter = new Counter;

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

Here, count() correctly returns the number of elements, while increment() is responsible for modifying the state of the object.

A separate discussion can be had about whether to use count($object) or $object->count(), but that’s a different topic.
Навигација

Прелистувај сродни теми и функции.

На оваа страница

Автоматски outline од активната документација.

Насловите ќе се појават тука по вчитување.

Попрегледно читање

Примерите, changelog табелите и user notes се визуелно издвоени за да не се губат во долгата содржина.

Брз совет Користи го outline-от Скокни директно на главните секции од активната страница.
Извор Оригиналниот линк останува достапен Кога ти треба целосен upstream context, отвори го PHP.net во нов tab.