您好,登錄后才能下訂單哦!
本篇文章為大家展示了PHP如何理解is_callable()和method_exists()函數,代碼簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細介紹希望你能有所收獲。
一、函數解析
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
二、函數測試
測試一:
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。
三、總結、
1、is_callable() 函數,可傳入的name類型有:函數字符串,匿名函數變量,類或類對象和方法名稱組成的數組。其函數第二參數,如果是true,則只驗證name是否是字符串或則是類或字符串1(類對象)和字符串二(方法名稱)組成的數組。而不驗證name是否為合法調用結構。如果是false,則驗證name是否為合法調用結構。
2、method_exists() 函數,不受訪問修飾符的影響,只要類方法存在,則返回true。函數is_callable()來說,如果驗證的類方法,訪問修飾符為protected或private 則返回false。
上述內容就是PHP如何理解is_callable()和method_exists()函數,你們學到知識或技能了嗎?如果還想學到更多技能或者豐富自己的知識儲備,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。