array ( 0 => 'index.php', 1 => 'PHP Manual', ), 'head' => array ( 0 => 'UTF-8', 1 => 'ja', ), 'this' => array ( 0 => 'function.is-callable.php', 1 => 'is_callable', ), 'up' => array ( 0 => 'ref.var.php', 1 => '変数操作 関数', ), 'prev' => array ( 0 => 'function.is-bool.php', 1 => 'is_bool', ), 'next' => array ( 0 => 'function.is-countable.php', 1 => 'is_countable', ), 'alternatives' => array ( ), 'source' => array ( 'lang' => 'ja', 'path' => 'reference/var/functions/is-callable.xml', ), ); $setup["toc"] = $TOC; $setup["toc_deprecated"] = $TOC_DEPRECATED; $setup["parents"] = $PARENTS; manual_setup($setup); ?>
(PHP 4 >= 4.0.6, PHP 5, PHP 7, PHP 8)
is_callable — 引数が、現在のスコープから関数としてコール可能な値かどうかを調べる
引数の内容が、callable かどうかを調べます。
value
チェックする値。
syntax_only
true
の場合、この関数は単に value
が関数またはメソッドであるかどうかだけを調べます。
文字列以外の型の変数や不正な形式の配列は、
引数として受け付けられません。有効な配列の形式は、
最初のエントリがオブジェクトあるいは文字列で、2 番目のエントリが文字列である
2 つのエントリからなるものです。
callable_name
"呼び出し名" を受け取ります。下の例では "someClass::someMethod" です。これは someClass::SomeMethod() が static メソッドであるかのようにみえますが、 そうではないことに注意しましょう。
例1 is_callable() の例
<?php
// 変数が、関数としてコール可能かどうかを確かめます。
//
// 関数名を含む単純な配列
//
function someFunction()
{
}
$functionVariable = 'someFunction';
var_dump(is_callable($functionVariable, false, $callable_name)); // bool(true)
echo $callable_name, "\n"; // someFunction
//
// メソッドを含む配列
//
class someClass {
function someMethod()
{
}
}
$anObject = new someClass();
$methodVariable = array($anObject, 'someMethod');
var_dump(is_callable($methodVariable, true, $callable_name)); // bool(true)
echo $callable_name, "\n"; // someClass::someMethod
?>
例2 is_callable() とコンストラクタ
is_callable() はコンストラクタを callable だとはみなしません。
<?php
class Foo
{
public function __construct() {}
public function foo() {}
}
var_dump(
is_callable(array('Foo', '__construct')),
is_callable(array('Foo', 'foo'))
);
上の例の出力は以下となります。
bool(false) bool(false)
true
を返します。
たとえそのメソッドが定義されていなくてもです。