PHP之数组和函数的基本教程
[PHP数组的分类]
按照下标的不同,PHP数组分为关联数组与索引数组
索引数组:下标从0开始,依次增长;
关联数组:下标为字符串格式,每个下标字符串与数字的值一一关联对应(有点像对象的键值对)
[关于关联数组和索引数组]
1、数组中可以同时存在关联数组和索引数组
array(1,2,3,"one"=>4)
2、数组所有的索引数组如果不加指定,会去掉关联向,默认增长(即关联数组不占索引位)
array(1,2,"one"=>4,4,5);//1,2,4,5的索引--->0/1/2/3
3、如果关联数组的key;是纯十进制整数字符串,则会将此数字转化为索引数组的索引值("10.0"/"08"等格式,仍然为关联数组,不转为索引)
array(1,2,"on3"=>4,"9"=>4,"010"=>5);//1,2,4的索引--->0/1/9
4、如果手动指定关联数组的key,索引数组的下标,如果与前面已有的key或下标重复,则后指定的值会覆盖之前的值; array(1,"one"=>2,0=>5,"one"=>6);-->打印数组 0=>5,"one"=>6;
5、如果手动指定索引数组下标,则后续自增长下标,会按照之前下标最大值,依次增长。
array(1,2,7=>3,4); 1,2,3,4的下标--->0,1,7,8
$arr1 = [1,2,3,4,5,6]//索引数组 var_dump($arr1); print_r($arr1); $arr2 = array("one"=>1,"two"=>2,"three"=>3);//关联数组 var_dump($arr2); $arr3 = array(1,"one"=>2,3,5=>4,5,6,"9"=>7,8,"haha"=>9); var_dump($arr3);
[数组的声明方式]
1、直接赋值声明;
2、[]字面量声明(PHP5.4版本之后能用)
3、Array()声明,没有new关键字
//1 $arr[]=1; $arr[3]=1; $arr[9]=1; $arr[4]=1; $arr[7]=1; $arr[]=1; var_dump($arr); //2 $arr = [1,2,3,"one"=>4,6]; var_dump($arr); //3 $arr = array(1,2,3,4,5); var_dump($arr);
[数组元素的读取]
PHP中数组支持[]和{}读取下标
$arr = [1,2,3,"one"=>4]; echo $arr[0]; echo $arr["one"]; echo $arr{"one"}; echo $arr{0};
[多维数组]
数组的一个值,依然是一个数组,我们称这种数组为多维数组
多维数组,不要求所有的项都为数组,可以是数组与普通值的混合
多维数组,也不要求每个子数组的限制个数
使用多维数组,一定要注意,数组中分隔用逗号
原则上,多维数组一般不超过3层使用
$h51701 =array( "gruop1"=>array( array("name"=>"张三","age"=>14,"sex"=>"男"), array("name"=>"张三","age"=>14,"sex"=>"男"), array("name"=>"张三","age"=>14,"sex"=>"男"), "groupName"=>"一组" ), "gruop2"=>array( array("name"=>"张三","age"=>14,"sex"=>"男"), array("name"=>"张三","age"=>14,"sex"=>"男"), array("name"=>"张三","age"=>14,"sex"=>"男") ), "gruop3"=>array( array("name"=>"张三","age"=>14,"sex"=>"男"), array("name"=>"张三","age"=>14,"sex"=>"男"), array("name"=>"张三","age"=>14,"sex"=>"男") ) ); var_dump($h51701);
遍历数组
使用for循环遍历数组
count($arr);用于统计数组元素的个数;
for循环只能用于遍历纯索引数组,!!!如果存在关联数组,count统计时会统计两种数组的总个数,使用for循环遍历混合数组,可能会导致数组越界
$arr = array(1,2,3,5,6,7); $num = count($arr);//count最好放到for外面,可以让函数只执行一次。 for($i=0;$i<$num;$i++){ echo "{$i}==>{$arr[$i]}"; }
foeEach循环遍历数组
foreach可以便利任何类型的数组
写法如下:
$arr = array(1,2,3,"one"=>4,5,6,7); foreach($arr as $item){ echo "{$item}<br/>"; }; $arr = array(1,2,3,"one"=>4,5,6,7); foreach($arr as $key=> $item){ echo "{$key}==>{$item}<br/>"; }
实例
$h51701 =array( "gruop1"=>array( array("name"=>"张三","age"=>14,"sex"=>"男"), array("name"=>"张三","age"=>14,"sex"=>"男"), array("name"=>"张三","age"=>14,"sex"=>"男") ), "gruop2"=>array( array("name"=>"张三","age"=>14,"sex"=>"男"), array("name"=>"张三","age"=>14,"sex"=>"男"), array("name"=>"张三","age"=>14,"sex"=>"男") ), "gruop3"=>array( array("name"=>"张三","age"=>14,"sex"=>"男"), array("name"=>"张三","age"=>14,"sex"=>"男"), array("name"=>"张三","age"=>14,"sex"=>"男") ) ); foreach ($h51701 as $key => $value) { echo "{$key}<br/>"; foreach ($value as $key1 => $value1) { echo "{$key1}<br/>"; foreach ($value1 as $key2 => $value2) { echo "{$key2}==>{$value2}<br/>"; } } };
3、使用list() each() while()遍历数组
list():用于将数组的每一个值,赋值给list函数的每一个参数。(list函数的参数,必须小于等于数组的元素个数)。
eg($a,$b,$c)=[1,2,3];-->$a=1; $b=2; $c=3;
注意:①list()在解析数组时,只解析索引数组。
②list可以通过空参数,选择性的解析数组的值
list($a,,$b)=[1,2,3]--->$a=1,$b=3
each():用于返回数组当前指针所在位的键值对,并将指针后移一位。
返回值:如果数组由下一位,返回一个数组。包含一个索引数组(0-键,1-值)和一个关联数组("key"-键,"value"-值);如果指针没有下一位,返回false
[使用list()/each()/while()配合遍历数组]
while(list($key,$value)= each($arr)){ echo "{$key}-->{$value}<br/>"; }; reset($arr);
数组使用完each()遍历完一遍后,指针始终处于最后一位的下一位,即再用each(),返回false
$arr = [1,2,3,4,5,6]; list($a,$b,$c,$d,$e,$f) = $arr;
echo "a-->{$a}<br/>";
echo "b-->{$b}<br/>";
echo "c-->{$c}<br/>";
echo "d-->{$d}<br/>";
echo "e-->{$e}<br/>";
echo "f-->{$f}<br/>";*/
while($a = each($arr)
① each($arr) 返回数组或false‘
② 把数组或false赋值给$a
③ while判断$a如果是数组,继续执行下一次、
如果$a是false,终止循环
while($a = each($arr)){ echo "{$a[0]}-->{$a[1]}<br/>"; echo "{$a['key']}-->{$a['value']}<br/>"; } while(true){ $a = each($arr); if($a){ echo "{$a[0]}-->{$a[1]}<br/>"; echo "{$a['key']}-->{$a['value']}<br/>"; }else{ break; } } while(list($key,$value)= each($arr)){ echo "{$key}-->{$value}<br/>"; }; reset($arr); while(list($key,$value)= each($arr)){ echo "{$key}-->{$value}<br/>"; }
4、使用数组指针遍历数组
①next():将数组指针后移一位,并返回后一位的值,没有返回false
②prev():将数组指针前移一位,并返回前一位的值,没有返回false
③end():将数组指针移至最后一位,并返回最后一位的值,空数组返回false
④reset():将数组指针恢复到第一位,并返回第一位的值。空数组返回false
⑤key():返回当前指针所在位的键;
⑥current():返回当前指针所在位的值;
$arr = [1,2,3,4,"one"=>5]; while(true){ echo key($arr); echo current($arr); echo "<br/>"; if(!echo next($arr)){ break; } } reset($arr); do{ echo key($arr); echo current($arr); echo "<br/>"; }while(echo next($arr)); reset($arr)
[超全局数组]
超全局数组,超全局变量、预定义数组、预定义变量说的都是他。
PHP给我们提供了一组包含强大功能的超全局数组,可以再任何地方,任何作用域不许声明,直接使用,不受任何作用域限制。
1 服务器变量: $_SERVER
2 环境变量:$_ENV
3 HTTP GET变量:$_GET
4 HHTP POST变量:$_POST
5 request变量:$_REQUEST
6 HTTP文件上传变量:$_FILES
7 HTTP Cookies:$_COOKIE
8 Session变量:$_SESSION
9 Global变量:$GLOBALS
1服务器变量: $_SERVER
$_SERVER是返回包含浏览器头信息,路径、脚本以及服务器系统等信息
var_dump($_SERVER); var_dump($_SERVER{'HTTP_USER_AGENT'});
2 环境变量:$_ENV
将系统环境变量,转变为PHP中的数组,就是$_ENV;
PHP默认是关闭此全局数组的。如需使用,需修改php.ini文件中的variables_order = "GPSC",改为variables_order = "EGPSC";
但是,修改后会有系统性能损失,官方并不推荐使用
可以使用getenv()函数取代全局变量,取出每个系统环境变量的值
phpinfo();函数:包含了有关PHP的各种信息,其中Environment板块是系统环境变量,可以使用getenv()取出其中的每一个值;
phpinfo(); echo getenv("System");
3 HTTP GET变量:$_GET
获取前台通过Get方式提交的数据;
var_dump($_GET); if(isset($_GET["submit"])){ if($_GET["username"]=="111"&&$_GET["pwd"]=="111"){ echo "登陆成功"; }else{ echo "登陆失败"; } }
4 HHTP POST变量:$_POST
获取前台通过POST提交的数据
if(isset($_POST["submit"])){ if($_POST["username"]=="111"&&$_POST["pwd"]==111){ echo "POST登陆成功"; }else{ echo "POST登陆失败"; }; }
var_dump($_POST);
5 request变量:$_REQUEST
包含了$_POST,$_GET和$_COOKIE的数组
由于request同时包含get和post,可能导致get与post键的冲突,并且效率也不高,所以,并不使用request。
var_dump($_REQUEST);
6 HTTP文件上传变量:$_FILES
7 HTTP Cookies:$_COOKIE
取到页面中的cookie信息
setcookie("cookie","haha"); $_COOKIE["hehe"]="haha"; var_dump($_COOKIE);
8 Session变量:$_SESSION
取到保存在Session中的信息
session_start(); $_SESSION["haha"]="hehe"; var_dump($_SESSION);
9 Global变量:$GLOBALS
$GLOBALS包含了上述8个全局数组,可以通过$GLOBALS["_SERVER"]收到$_SERVER
还可以通过给$GLOBALS数组追加下标,创建全局变量,可以再函数里函数外随意访问:
$GLOBALS["name"]="zhangsan"; var_dump($GLOBALS);
返回数组所有的值,返回数组
var_dump(array_values($arr));
返回数组所有的键,返回数组
var_dump(array_keys($arr));
数组中是否包含某个值,返回真假
参数:需要查询的值,数组,true(===)/false(==)
var_dump(in_array(8, $arr,true));
交换数组中的键和值,返还新数组
var_dump(array_flip($arr));
反转数组,返回新数组
参数:①需要反转的数组
②true:保留原有索引数组的下标与值的匹配
false:只反转值,键不保留。默认。
无论true/false都不会影响关联数组,关联数组总会保留,键值永远是一对。
var_dump(array_reverse($arr,true));
统计数组元素个数
count($arr);
统计数组中,所有值出现的次数,返回一个新数组
新数组格式:建--> 元数组的值(去重 后的值)
值--> 元数组对应的值出现的次数
var_dump(array_count_values($arr));
$arr = array(1,2,3,4,5,6,"a"=>7,"b"=>8,"c"=>9,10); $arr1 = array('J. Karjalainen', 'J. Karjalainen', 60, '60', 'J. Karjalainen', 'j. karjalainen', 'Fastway', 'FASTWAY', 'Fastway', 'fastway', 'YUP'); $arr2 = array();
1、有一个空数组arr2,键-->原数组去重的值,值-->原数组每个值出现的次数。
2、遍历原数组arr1,并去除arr1中的每一个值。
3、检测新取出的这个值,是否在arr2中,有一个同名的键。
如果有:说明找到了与现在新数组想重复的值,那么就把arr2中的这个键对应的值+1
如果没有:说明截止现在,还没有与新取值重复的项,那么就在arr2中 新建一个同名的键,让值为1;
foreach($arr1 as $key1 => $value1) { $isHas = false; foreach($arr2 as $key2 => $value2) { if($key2 == $value1) { $rarr2[$value1]++; $isHas = true; } } if(!isHas) $arr2[$value1] = 1; }
移除数祖中重复的值
var_dump(array_unique($arr));
过滤数祖中的每一个值
①不传回调函数,过滤掉所有的空值,(0/""/false/"0"/[])
②传回调函数,需要给回调函数传递一个参数,判断参数是否符合要求,如果符合,return true;否则,return false;
var_dump(array_filter($arr,function($num){ if($num>4){ return true; }else{ return false; } }))
通过回调函数,对数组的每一给值进行处理操作。直接修改原数组并返回bool类型的是否成功
执行时,会给回调函数传递两个参数,分别是数组的value,key。然后可以再回调函数中,对值和减进行处理。
但是!!!牵扯到修改值的时候,必需要传递地址!!!
$fruits = array("a"=>"lemon","b"=>"orange","c"=>"apple"); var_dump(array_walk($fruits,function(&$item,$key){ echo "{$key}-->{$item}<br/>"; $item =$key; },"10")); var_dump($fruits);
将数组的每个值,交由回调函数进行映射处理
array_map();第一个参数是一个回调函数,第二个参数起是>=1个数组
有几个数组可以给回调函数传几个参数,表示每个数组的一个value;
可以对value进行处理,处理完以后通过return返回,那么新数组的对应的值就是return回去的值
【array_map与array_walk的异同】
相同点:都能遍历数组,通过回调函数,重新处理数组的每一个值
不同点:
①walk只能传一个数组,回调函数接受这个数组的值和键
map可以传多个数组,回调函数接受每个数组的值
②walk直接修改原数组,而map不修改原数组,将新数组返回;
③walk可以给回调函数传递一个其余参数,map只能传数组的值
④处理方式上,walk如果需要改掉原数组的值,需在回调函数中传递地址,直接修改变量的值;
map是通过将新的值,用return返回,即可修改新数组的值
$a = [1,2,3,4,5]; $b = [1,2,3,4]; $arr2 = array_map(function($value1,$value2){ return $value1+$value2; },$a,$b); var_dump($arr2);
sort -- 对数组排序(升序),可传入第二个参数,控制以何排序,第二个参数传1,表示按照数字排序,2表示按字符串排序,自动检测
rsort -- 对数组逆向排序(降序)
usort -- 使用用户自定义的比较函数对数组中的值进行排序
usort($arr,function($a,$b){
//return $a-$b;升序
//return $b-$a;降序
});
下述3个函数,常用于(关联数组排序),用法同上
asort -- 对数组进行排序并保持索引关系
arsort -- 对数组进行逆向排序并保持索引关系
uasort -- 用户自定义的比较函数对数组进行排序并保持索引关联
ksort -- 对数组按照键名排序
krsort -- 对数组按照键名逆向排序
uksort -- 使用用户自定义的比较函数对数组中的键名进行排序
自然排序 :数字按照0-9,字母按照a-z进行排序
下面两个函数,都是按照自然排序,并且排序时会保留键值关联
natsort -- 用“自然排序”算法对数组排序
natcasesort -- 用“自然排序”算法对数组不区分大小写字母排序
array_multisort -- 对多个数组或多维数组进行排序
第一个参数时第一个数组,
之后都是可选参数,SORT_ASC - 按照上升顺序排序 /SORT_DESC - 按照下降顺序排序 ,SORT_NUMERIC - 将项目按照数字比较/SORT_STRING - 将项目按照字符串比较 、
在之后,就是多个可选数组。
排序规则:先排第一个数组,之后的数组,按照与第一个数组对应的关系:一列一列的移动!!!
如果对多个数祖排序,需保持多个数组长度一致,否则会报警告。
$arr = array[1,2,5,7,9,13,18]; echo SORT_STRING; sort($arr,SORT_STRING); usort($arr,function($a,$b){ //return $a-$b;升序 //return $b-$a;降序 }); var_dump($arr);
$arr1 = [1,2,3,4,5,6,7]; $arr2 = [3,5,6,7,8,1,0]; array_multisort($arr1,SORT_DESC,SORT_NUMERIC,$arr2); var_dump($arr1); var_dump($arr2);
$arr = array[1,2,3,4,5,6,"one"=>7,8,9,"haha"]; array array_slice ( array $array , int $offset [, int $length = NULL [, bool $preserve_keys = false ]] )
①数组,必须
②从第几位开始截取,必选,负数表示,从右边数第几位(按照数组的默认顺序,包括关联,索引,而不是按照下标)
③截取的长度,可选,默认,截到最后
④Boolean类是否保持键值关联,可选,默认,索引重新排序,传true保持索引关联
$arr1 = array_slice($arr,2,5); var_dump($arr1);
array array_splice ( array &$input , int $offset [, int $length = 0 [, mixed $replacement ]] )
返回值:被删掉的数组;
参数:
①数组的地址,会修改原数组
②从第几位开始删,替换
③删除或替换的长度
④为空,表示删除操作,传入内容,表示替换操作的新值
$arr = array[1,2,3,4,5,6,"one"=>7,8,9,"haha"]; $arr1 = array_splice($arr,4,5,[0,0,0,0]); var_dump($arr1); var_dump($arr);
array_combine — 创建一个数组,用一个数组的值作为其键名,另一个数组的值作为其值
array_combine(作为键的数组,作为值的数组)
两个数组必须保持一致,否则警告,返回false;
$arr1 = [1,2,3,4,5]; $arr2 = [6,7,8,9,0]; $arr3 =array_combine($arr1, $arr2); var_dump($arr3);
合并数组
array array_merge ( array $array1 [, array $... ] )
合并多个数组,将后面的数组拼接到前面的数组的后面
如果多个数组中,出现同名的关联键值,则后面的会覆盖前面
$arr1 = [1,2,3,"a"=>4,"10"=>5]; $arr2 = [6,7,8,"a"=>9,"10"=>0]; $arr3 = array_merge($arr1,$arr2); var_dump($arr3);
数组取交集
array array_intersect ( array $array1 , array $array2 [, array $ ... ] )
*多个数组取交集,结果会保留第一个数组的键值关联匹配。
$arr1 = [1,2,9,"a"=>4,5]; $arr2 = [6,7,8,"a"=>9,"10"=>5]; $arr3 = array_intersect($arr1, $arr2); var_dump($arr3);
数组取差集
array array_diff ( array $array1 , array $array2 [, array $... ] )
取出多个数组中,在第一个数组中包含,但是在其他数组中不包含的值,保留第一个数组的键值关联
$arr1 = [1,2,9,"a"=>4,5]; $arr2 = [6,7,8,"a"=>9,"10"=>5]; $arr3 = array_diff($arr1, $arr2); var_dump($arr3);
array_pop 删除数组的最后一个值,并且返回这个值
array_push 数组的最后,放入1-多个值,返回处理之后的数组元素个数
array_shift 删除数组的第一个只,并且返回这个值
array_unshift 数组的开头,放入1-多个值,返回处理之后的数组元素个数
array_rand:随机抽取数组中的1到多个键名,第二个参数为空,表示抽一个,传入数字,表示抽N个。
$arr1 = [1,2,3,4,5,6,7]; var_dump(array_rand($arr1,3));
shuffle:随机打乱数组顺序,直接修改原数组
$arr1 = [1,2,3,4,5,6,7]; shuffle($arr1); var_dump($arr1);
[函数的声明与使用]
1、函数名是标志符之一,只能有字母,数字,下划线,开头不能使数字
函数名的命名:须符合小驼峰法则,:myNameIsJh my_name_is_jh
函数名不区分大小写,func(); FUNC(); Func();
函数名不能与已有函数名重复,,不能与系统函数名重复
2、function_exists("func");用于函数是否以声明
注意:传入的函数名,必须是字符串格式,返回的结果为true/false;
[PHP中变量的作用域]
1、局部变量:声明在函数内的变量,称为局部变量,只能在函数内部使用,函数外部如需使用,需在函数中使用return关键字返回。
2、全局变量:声明函数外部的变量,称为全局变量。
3、函数中,使用变量。默认使用内部局部变量,如果,需在函数中使用全局变量,需要使用global关键字,将全局变量引入函数,才能使用
函数中的变量名:如果与全局变量重复,global语句之上,为函数局部变量。global语句之下,为系统全局变量
4、$GOLBALS[]全局数组
$GOLBALS[]数组,是PHP给我们内置的全局数组,可以直接给数组添加值,无论寒暑内外声明,均可在任何地方直接使用
$GLOBALS["a3"]=40; echo $GLOBALS["a3"]; //任何位置直接使用
5、函数中使用全局变量还有一种方式,通过给函数传参,可以在函数内部使用全局变量
但是,传递以后的参数势函数的局部变量,内部改变,外部不会变。
除非。传递的参数是地址 function func($a1,$a2){}// 函数内部修改a1,则全局a1不会变,函数内部修改a2,则全局a2会变。
如果函数的形参,出现了取址符号,则调用函数时,实参必须是变量,而不能使自变量,例如func($a1,$a2);√ func($a1,2);×
6、使用require与include包含不会影响作用域
[静态变量]
1、静态变量使用static关键字声明, static $num=1;
2、静态变量的特点:静态变量在函数的第一次加载的时候进行声明,函数使用完不会立即释放静态变量,静态变量在整个脚本过程中,只会声明一次。
同一函数,多次调用,共享同一个静态变量。
[函数的参数传递]
0、在PHP中,设计参数传递时,实参列表只能
1、常规参数传递 function func($a){} func($a);
2、引用参数传递 function func(&$a){} func($a);
① 通过&引用参数传递,函数内修改变量,函数外同步变化
② 形参为引用参数,实参只能是变量,不能是自变量 func(10);
3、默认参数:function func($a=10,$b){}; func(20);//$a的量不变,默认为10;$b必须赋值,否则就会未定义报错。
function func($b,$a=10){return $a+$b;} func(30);
如果参数中既有默认参数,又有非默认参数,那么。默认参数要在非默认参数的后面,及调用是,要保证非默认参数列表的先赋
4可变参数列表:由于PHP实参可以比形参多,那么我们可以传递n个实参,并通过PHP内置参数取到对应参数
var_dump(func_get_args());//区所有参数列表
var_dump(func_num_args());//返回参数的总个数
var_dump( func_get_arg());//根据下标。取每个参数
[变量函数]
1、将一个函数名,转为字符串后,赋给一个变量,这个变量,就是我们所说的变量函数,可以加()调用函数,
function func(){}--->$fun = "func"--->$func()
[回调函数]
1、使用变量函数,自定义回调函数
function func($func){$func();} -->function f(){};-->func("f");
2、使用call_user_func_array和call_user_func自定义回调函数
两个函数的第一个参数,均为回调函数,表示执行当前回调
不通电在于:call_user_func_array()第二个参数维数组,并将数组的每一个值赋给回调函数的参数列表,,相当于JS中的apply();
而:call_user_func() 是将回调函数的参数列表,直接展开写到第二个到多个参数中,相当于JS中的call(); eg:call_user_func_array("func",array(1,2,3));-->func(1,2,3)
call_user_func("func",1,2,3);-->func(1,2,3)
// 简单的函数声明 function func(){ echo "jianghao"; } func(); FUNC(); // 检测函数是否存在 var_dump(function_exists("func")); //变量的作用域 $a1=10; $haha1=20; $haha2 = 20; $GLOBALS["a3"]=40; function func($haha1,&$haha2){ $a1 = 30; echo "0.{a1}<br/>";//global之上使用局部变量 echo $GLOBALS["a3"]."<br/>";//使用$GLOBALS["a3"]数组 $GLOBALS["a4"]=50; global $a1; $a2 =20; echo "1.{a1}<br/>";//global之下使用全局变量 echo "2.{a2}<br/>"; //使用函数内部局部变量 $haha1=20;//是通过全局haha1赋值而来 $haha2 = 30;//是通过全局haha2赋地址而来 return $a2; } $a2 = func($haha1,$haha2); echo "3.{a1}<br/>";//使用全局变量 echo "4.{a2}<br/>";//通过return返回,通过变量接受 echo "5.{$GLOBALS["a4"]}<br/>";//函数中使用$GLOBALS[]声明,函数外使用。 echo "6.{$haha1}<br/>";//形参为传值,函数内改变,全局不变 echo "7.{$haha2}<br/>";//形参为传地址,函数内改变,全局也变
静态变量
function func(){ static $num = 0; $num++; echo $num."<br/>"; } func();
常规参数传参
功能:将传入的参数,+10后返回
Number func(Number params) function func($a){ $a +=10; return $a; } echo func(10);
引用类型参数
function func(&$a){ $a +=10; } func($a); //通过取值符号,可以直接将传入的$a的之改掉 echo $a;
默认参数
function func($b,$a=10){ return $a+$b; } func(30);
可变参数列表
function func(){ $arr =func_get_args(); var_dump(func_get_args());//区所有参数列表 var_dump(func_num_args());//返回参数的总个数 var_dump( func_get_arg());//根据下标。取每个参数 var_dump(&arr[0]);//同上 for($i=0;$i<func_num_args();$i++){ $num = func_num_args($i) } return $sum; } echo func(1,2,3,4,5);
变量函数
function func($a){ echo "杰瑞教育!{$a}<br/>"; } func(); $fun = "func"; $fun(20); //自定义回调函数 function func($start,$end,$func){ for($i=$start;$i<=$end;$i++){ $func($i) if($func($i)){ echo "{$i}<br/>"; } } } function fliter($num){ if($num%3!=0){ return true; }else { return false; } } function fliter1($num){ if($num>20&&$num%5==0){ return true; }else { return false; } } func(1,100,"fliter1"); func(10,30,function($num){ return true; });
使用call_user_func_array和call_user_func自定义回调函数
function func(){ $arr = func_get_args(); $str = ""; for($i=0;$i<count($arr);$i++){ $str.= $arr[$i]; } return $str; } //apply echo call_user_func_array("func",array("jierui","edu","h51701","web")); //相当于,执行func函数,并且把数组中的每一项作为参数传入。 echo "<br/>"; //call echo call_user_func("func","jierui","h51701","edu")
[匿名函数]
1、由于变量函数在调用时存在多种调用方式,(func()/$Fun();)
所以为了让函数的调用更为同一,才产生了匿名函数
!!!声明匿名函数,函数体后面的分号必不可少。
!!!匿名函数本身也是变量,用var_dump()检测为object类型。
$func =function($param){ echo "我是匿名函数{$param}<br/>"; }; $func(10); var_dump($func);
[递归函数]
1、所谓递归,指的是在函数内部,调用函数自身的操作
2、递归分为两步:递、归
递:从最外层函数依次往里调用自身
归:最内层函数执行完后,在逐步向外调用外层函数的后半部分
当最外层函数体中,遇到自身函数调用,继续进入内层函数执行,而最外层函数的后半部分暂不执行,指导最内层函数执行完毕后,在逐步向外执行
function func($num){ echo $num."<br/>"; if($num>0){ func($num-1); } echo $num."<br/>"; } func(10);
使用递归求1-10的阶乘
function func($num){ static $jie=1; if($num>0){ $jie *=$num; func(--$num); } return $jie; } echo func(10);
[include&rquire]
1、两者的作用,都是用于引入外部的PHP文件到当前文件中;
2、两者的区别:当引入的文件错误时,include会产生警报,并不影响后续代码执行,而require会产生致命错误,后续代码全部不再执行。
3、一般,应用于在文件最上方导入某些文件时使用require导入,如果导入失败,则不执行文件。而,如果在某些分支条件中,导入某些分支结构。一般使用include导入。一旦出错,分支不执行。
4、include_once和require_once表示:文件只能导入一次,如果多次调用此函数,则后面的语句会判断文件是否导入,在决定是否导入新文件。
(检测文件是否导入时,只关心文件是否已经导入,并不关心使用何种方式导入的。)
include('text.txt')
require_once('text.txt');//由于include进来了,require不在导入
5、include和require可以导入各种类型的文件,相当于在当前文件copy一份,但是在copy过程中,PHP引擎会进行适当的编译,确保不会出错。
6、include和require势函数,也是指令,PHP对于很多常用函数,会提供执行的写法,例如echo("11");//函数写法 echo "11"//指令写法
require 'function.php'; include 'function.php'; func1(); func2(); func3();
[PHP闭包]
在PHP中,子函数无法直接访问父函数的局部变量,必须使用use关键字向下传递。