1、函数解析
is_callable()
界说:
(PHP 4 >= 4.0.6, PHP 5, PHP 7)
is_callable — 检测参数能否为非法的可挪用构造
bool is_callable ( callable $name
[, bool $syntax_only
= false [, string &$callable_name
]] )
验证变量的内容是否作为函数挪用。 这能够反省蕴含无效函数名的变量,或许一个数组,蕴含了正确编码的工具和函数名。
参数:
name
要反省的回调函数。
syntax_only
假如设置为 TRUE
,这个函数仅仅验证 name
多是函数或办法。 它仅仅回绝非字符,或许未蕴含能用于回调函数的无效构造。无效的应该蕴含两个元素,第一个是一个工具或许字符,第二个元素是个字符。
callable_name
承受“可挪用的称号”。上面的例子是“someClass::someMethod”。 留意,虽然 someClass::SomeMethod() 的含意是可挪用的动态办法,但例子的状况并非这样的。
前往值:
假如 name
可挪用则前往 TRUE
,不然前往 FALSE
。
参考文献: http://php.net/manual/zh/function.is-callable.php
2、函数测试
测试一:
echo '<pre >'; $func = function ($a) { echo $a; }; $re = is_callable($func, true, $callable_name1); echo '<hr />'; $re1 = is_callable($func, false, $callable_name2); //后果 bool(true) string(17) "Closure::__invoke" ------------------------------------- bool(true) string(17) "Closure::__invoke"
测试后果:
关于匿名函数,传入函数变量后,参数二syntax_only true 以及 false,打印后果是同样的。
测试二:
function c_b($d) { echo $d; } $re = is_callable('c_b', false, $callable_name1); $re1 = is_callable('c_b', true, $callable_name2); var_dump($re); echo '<hr />'; var_dump($re1); echo '<hr />'; var_dump($callable_name1); echo '<hr />'; var_dump($callable_name2); //后果 bool(true) ---------------- bool(true) ---------------- string(3) "c_b" ---------------- string(3) "c_b"
测试后果:
关于普通函数,传入函数称号后,参数二syntax_only true 以及 false,打印后果是同样的。
测试三:
class Person { public static function get($a) { echo $a; } protected function _set() { echo 1; } } $p = new Person(); $re = is_callable([$p, 'get'], false, $callable_name1); $re1 = is_callable([$p, 'get'], true, $callable_name2); var_dump($re); echo '<hr />'; var_dump($re1); echo '<hr />'; var_dump($callable_name1); echo '<hr />'; var_dump($callable_name2); //后果 bool(true) ----------------- bool(true) ----------------- string(11) "Person::get" --------------------------- string(11) "Person::get"
测试后果:
关于类的办法,参数以数组构造(类工具或类称号 + 办法称号),参数二syntax_only true 以及 false,打印后果也是同样的。
测试四:
$a = 'i am string'; $re = is_callable($a, false, $callable_name1); $re1 = is_callable($a, true, $callable_name2); var_dump($re); echo '<hr />'; var_dump($re1); echo '<hr />'; var_dump($callable_name1); echo '<hr />'; var_dump($callable_name2); //后果 bool(false) ---------------- bool(true) ---------------- string(11) "i am string" ------------------------- string(11) "i am string"
测试后果:
关于传入的验证name,假如syntax_only 设置为true,它验证传入name能否是字符串,能否含有合法字符,假如没有含有,则前往true,它其实不会验证name能否为非法挪用构造。
测试五:
$re = is_callable(['Class', 'Method'], false, $callable_name1); $re1 = is_callable(['Class', 'Method'], true, $callable_name2); var_dump($re); echo '<hr />'; var_dump($re1); echo '<hr />'; var_dump($callable_name1); echo '<hr />'; var_dump($callable_name2); //后果 bool(false) -------------- bool(true) -------------- string(13) "Class::Method" ----------------------------- string(13) "Class::Method"
测试后果:
关于传入的验证name,假如syntax_only 设置为true,它只验证传入name能否是字符串,能否含有合法字符或能否为数组参数字符串1 + 字符串二,假如合乎前提,则前往true,它其实不会验证name能否为非法挪用构造。否者前往false;
测试六:
class Person { public static function get($a) { echo $a; } protected function _set() { echo 1; } } $p = new Person(); $re = is_callable([$p, '_set'], false); var_dump($re); echo '<hr />'; $re1 = method_exists($p, '_set'); var_dump($re1); //后果 bool(false) ------------ bool(true)
测试后果:
关于函数is_callable() 来讲,假如验证的类办法,拜访润饰符为protected或private 则前往false。
关于method_exists() 来讲,则没有受拜访润饰符的影响,只需类办法存正在,则前往true。
3、总结、
一、is_callable() 函数,可传入的name类型有:函数字符串,匿名函数变量,类或类工具以及办法称号组成的数组。其函数第二参数,假如是true,则只验证name能否是字符串或则是类或字符串1(类工具)以及字符串二(办法称号)组成的数组。而没有验证name能否为非法挪用构造。假如是false,则验证name能否为非法挪用构造。
二、method_exists() 函数,没有受拜访润饰符的影响,只需类办法存正在,则前往true。函数is_callable()来讲,假如验证的类办法,拜访润饰符为protected或private 则前往false。
相干教程:PHP视频教程
以上就是PHP学习之深化了解is_callable()以及method_exists()函数的具体内容,更多请存眷资源魔其它相干文章!
标签: php开发教程 php开发资料 php开发自学 method_exists() PHP.is_callable()
抱歉,评论功能暂时关闭!