call_user_func 和 call_user_func_array用法
说明
call_user_func 和 call_user_func_array
相同:都可以调用函数和类内部的函数,
不同:不同的是传递的参数不同,前者是一个参数一个参数传递, 后者是传递array参数
一:call_user_func 用法
1.1 调用函数
<?php
function funcA($a) {
echo $a;
} function funcB() {
$args = func_get_args();
print_r($args);
} call_user_func('funcA', 'testA');
call_user_func('funcB', 'testA', 'testB');
1.2 类内部函数调用
class clsA {
// func_get_args() 函数获取参数
public function funcA() {
$args = func_get_args();
$num = func_num_args();
print_r($args);
echo $num;
}
public static function funcB() {
$args = func_get_args();
$num = func_num_args();
print_r($args);
echo $num;
}
public static function funcC($a, $b) {
echo $a.' - ' . $b;
}
}
call_user_func(array('clsA', 'funcA'), 'arg1', 'arg2');
call_user_func('clsA::funcB', 'argb1', ' argb2');
call_user_func('clsA::funcC', 'argc1', 'argc2');
二:call_user_func_array 用法
从上面的例子可以看到 func_get_args() 可以获取函数的参数,而且是数组形式的参数,那么能不能直接传给函数呢,对,就是这个 call_user_func_array
2.1 调用函数
<?php
//直接传递参数
function funcC($a, $b) {
echo $a .' - '. $b;
} //用 func_get_args() 函数获取传递的参数
function funcD($a, $b) {
$args = func_get_args();
print_r($args);
}
//后面传递的是array参数
call_user_func_array('funcC', array('1', '2'));
call_user_func_array('funcD', array('d1', 'd2'));
2.2 类内部函数调用
class funcE {
//直接获取参数
static function funcA($a, $b) {
echo " " .$a . ' - ' . $b;
}
//用func_get_args()获取参数
static function funcB() {
$args = func_get_args();
print_r($args);
}
}
// 2种调用方法
//这样调用
call_user_func_array(array('funcE', 'funcA'), array('1', '2'));
call_user_func_array(array('funcE', 'funcB'), array('1', '2', 3));
//或者这样调用
call_user_func_array('funcE::funcA', array('1', '2'));
call_user_func_array('funcE::funcB', array('1', '2', 3));
call_user_func 和 call_user_func_array用法的更多相关文章
- PHP函数call_user_func和call_user_func_array详解
今天在群里面,有个叫lewis的在问call_user_func_array的用法,因为之前一直没有用过,也不能说什么,于是看一下手册,发现是这么写的: call_user_func_array (P ...
- PHP回调函数call_user_func()和call_user_func_array()的使用
call_user_func():把第一个参数作为回调函数调用 用法:call_user_func ( callable $callback [, mixed $parameter [, mixed ...
- php中call_user_func 与 call_user_func_array的使用
call_user_func()是利用回调函数处理字符串,call_user_func_array是利用回调函数处理数组. // 1. 调用自定义函数 function test($a, $b) { ...
- php自定义函数call_user_func和call_user_func_array详解
看UCenter的时候有一个函数call_user_func,百思不得其解,因为我以为是自己定义的函数,结果到处都找不到,后来百度了一下才知道call_user_func是内置函 call_user_ ...
- php call_user_func和call_user_func_array
首先要看这个页面关于callable类型:http://www.php.net/manual/zh/language.types.callable.php 自 PHP 5.4 起可用 callable ...
- PHP中的call_user_func()与call_user_func_array()简单理解
原文地址:http://small.aiweimeng.top/index.php/archives/52.html call_user_func:把一个参数作为回调函数调用 用法说明: call_u ...
- php中call_user_func()与call_user_func_array()区别
call_user_func:把一个参数作为回调函数调用 用法说明: call_user_func ( callable $callback [, mixed $parameter [, mixed ...
- 简单理解call_user_func和call_user_func_array两个函数
call_user_func():调用一个回调函数处理字符串, 可以用匿名函数,可以用有名函数,可以传递类的方法, 用有名函数时,只需传函数的名称 用类的方法时,要传类的名称和方法名 传递的第一个参数 ...
- call_user_func 与call_user_func_array 的使用与区别
1 call_user_func 的使用 1)使用方法直接传递值 function nowamagic($a,$b){ echo $a; echo $b; } call_user_func('nowa ...
随机推荐
- Practice5.1 测试与封装5.1
结对同伴: 姓名 学号 博客地址 叶子鹏 201306114420 http://www.cnblogs.com/kazehanaai/ 王佳宁 201306114434 http://www.cnb ...
- 第三个spring冲刺第5、6、7天(三天汇总)
这三天我们一直在研究选择题的选项插入与切换,现在已经大致完善了,达到了预想的效果,晚点会补上截图.
- redis的优缺点
优点: 1 读写性能优异 2 支持数据持久化,支持AOF和RDB两种持久化方式 3 支持主从复制,主机会自动将数据同步到从机,可以进行读写分离. 4 数据结构丰富:除了支持string类型的value ...
- [转]Spring通过@Value注解注入属性的几种方式
原文地址:https://blog.csdn.net/csujiangyu/article/details/50945486 ------------------------------------- ...
- Minor GC vs Major GC vs Full GC
http://www.importnew.com/15820.html https://plumbr.io/blog/garbage-collection/minor-gc-vs-major-gc-v ...
- TCP 三次握手理解和过程
1:TCP为什么要三次握手,不是两次四次? 2:TCP协议三次握手过程分析
- Lodop图片输出ADD_PRINT_IMAGE 有白边
ADD_PRINT_IMAGE输出图片,如果使用img标签(即超文本<img标签),是超文本,无论是相对路径,网络图片,还是base64,都可能有白边,这可能和超文本解析有关.ADD_PRINT ...
- Docker容器从一知半解到入门
Docker是一个开源的.跨平台的应用容器引擎,可以让技术开发认用打包他们的应用以及一些依赖包到一个可移植的容器平台中,发布到任何流行的Linux操作系统上面,也可以在Windows和mac操作系统上 ...
- linux 内核参数优化----最大线程数限制及当前线程数查询
1.总结系统限制有: /proc/sys/kernel/pid_max #查系统支持的最大线程数,一般会很大,相当于理论值 /proc/sys/kernel/thread-max max_user_p ...
- BZOJ3510 首都(LCT)
即动态维护树的重心.考虑合并后的新重心一定在两棵树的重心的连线上.于是对每个点维护其子树大小,合并时在这条链的splay上二分即可.至于如何维护子树大小,见https://blog.csdn.net/ ...