Возвращает объявленные по умолчанию свойства класса


(PHP 4, PHP 5)

get_class_varsВозвращает объявленные по умолчанию свойства класса

Описание

array get_class_vars ( string $class_name )

Возвращает объявленные по умолчанию свойства указанного класса.

Список параметров

class_name

Имя класса

Возвращаемые значения

Возвращает ассоциативный массив объявленных свойств класса, видимых из текущей области видимости, с их значением по умолчанию. Получившиеся элементы массива имеют форму varname => value. В случае ошибки возвращается FALSE.

Список изменений

Версия Описание
5.0.3 В зависимости от области видимости, get_class_vars() вернет только те свойства, доступ к которым может быть получен из текущей области видимости.
5.0.2 Вызов get_class_vars() не вернет все свойства в качестве массива, в отличие от предыдущего поведения, где protected и private свойства имели префикс с нулевым байтом.
5.0.1 Вызов get_class_vars() покажет все свойства, как при конвертировании объекта в класс.

Примеры

Пример #1 Пример использования get_class_vars()

<?php

class myclass {

    var 
$var1// переменная не имеет начального значения...
    
var $var2 "xyz";
    var 
$var3 100;
    private 
$var4// PHP 5

    // конструктор
    
function myclass() {
        
// change some properties
        
$this->var1 "foo";
        
$this->var2 "bar";
        return 
true;
    }

}

$my_class = new myclass();

$class_vars get_class_vars(get_class($my_class));

foreach (
$class_vars as $name => $value) {
    echo 
"$name : $value\n";
}

?>

Результат выполнения данного примера:

 // До PHP 4.2.0 var2 : xyz var3 : 100  // Начиная с PHP 4.2.0 var1 : var2 : xyz var3 : 100 

Пример #2 get_class_vars() и поведение области видимости

<?php
function format($array)
{
    return 
implode('|'array_keys($array)) . "\r\n";
}

class 
TestCase
{
    public 
$a    1;
    protected 
$b 2;
    private 
$c   3;

    public static function 
expose()
    {
        echo 
format(get_class_vars(__CLASS__));
    }
}

TestCase::expose();
echo 
format(get_class_vars('TestCase'));
?>

Результат выполнения данного примера:

 // 5.0.0 a| * b| TestCase c a| * b| TestCase c  // 5.0.1 - 5.0.2 a|b|c a|b|c  // 5.0.3 + a|b|c a 

Смотрите также

  • get_class_methods() - Возвращает массив имен методов класса
  • get_object_vars() - Возвращает свойства указанного объекта