I am working on a project, in which I am using a deprecated function from the older version. But don\'t want my script to stop if used in the older version.
So I am check
One more different:
If you have a class which uses __call magic method, the is_callable($object, $method)
will always return true for anything because __call
basically accepts every method name. And as you might already know, method_exists
will return false for this if the method is not defined in the class.
This is especially annoying if you use CakePHP Model
class as they implemented __call
magic method to provide magic queries, but not cool if you want the method to be absolutely defined.
If a function Plop
exists then function_exists("Plop")
will return true.
See function_exists
If a variable is callable then is_callable($var)
will return true.
Now this could mean that $var
is a function name.
But i could also be an object and method name combo.
See is_callable
When used with a function (not a class method) there is no difference except that function_exists
is slightly faster.
But when used to check the existence of methods in a class you cannot use function_exists
. You'll have to use is_callable
or method_exists
.
The function is_callable accepts not only function names, but also other types of callbacks:
Foo::method
array("Foo", "method")
array($obj, "method")
So is_callable
accepts anything that you could pass call_user_func and family, while function_exists only tells if a certain function exists (not methods, see method_exists for that, nor closures).
Put another way, is_callable
is a wrapper for zend_is_callable, which handles variables with the pseudo-type callback, while function_exists
only does a hash table lookup in the functions' table.
When used in class context, is_callable
returns true for class methods that are accessible ie public methods but method_exists
returns true for all methods - public, protected and private. function_exists
does same thing as method_exists
outside class contexts.