Maison  >  Article  >  développement back-end  >  PHP半路出家(2)_PHP教程

PHP半路出家(2)_PHP教程

WBOY
WBOYoriginal
2016-07-13 17:50:57824parcourir

函数是每个编程语言必不可少的,我得了解了PHP有什么不同
最犀利的就是返回类型,不用在函数声明注明
唯一需要注意的是你得用对应的类型接收返回值~
C++里的老面孔

按引用传值"&"
默认参数
递归函数---画表单的利器!
 

 

英雄不问出处,弱类型造就的是有灵魂的数组
 

赋值方式:
 
$say = array("Chinese" , "English" , "French");
//相当于
$say[0] = "Chinese"  ;    $say[1] = "English"  ;   $say[2] = "French"   ;

 


 $say = array("China"=>"Chinese" , "England"=>"English" , "France"=>"French");

//相当于

$say["China"] = "Chinese"  ;

$say["England"] = "Chinese"  ;

$say["France"] = "Chinese"  ;
 

 

 

PHP的数组不同于java的数组,是一种综合了数组和map的感觉

$myArray = array(0=>"第0个","2"=>"2了","这都行"=>"这真可以");

echo $myArray[0];                  //正常模式

echo $myArray[1];                 //没有值的按空算

echo $myArray[2];                 //会输出"2了"

echo $myArray["2"];              //也会输出"2了"

echo $myArray["这都行"];           //会输出"这真可以"
 

索引自动递增

$myArray[] =0;

$myArray[] =1;

$myArray[] =2;

$myArray[] =3;

echo $myArray[3];     //会输出3
 

强大的list()可以提取数组---涉及匹配函数explore(),以后再说~
 

Range()函数也有筛选的作用
$myArray =  range("a", "z",3);    //从"a"到"z",每隔3个输出一个

//输出a d g j m p s v y

 

数组拓展 www.2cto.com
返回索引对应的值 :
print_r($myArray );

判断是否为数组:
boolean is_array(mixed var);

混合的 --- 队列+栈 --- 前后都很方便的操作  

array_unshift($vars , $key , $value);    //从头加

array_push($vars , $key , $value);       //从尾加

array_shift($vars );    //从头删:

array_pop($vars );     //从尾删:
 

数组四问 --- 查询
数组问  :   你在吗?
//对于key   :   
boolean array_key_exists($key  ,  $vars   );
//对于value   :  
boolean in_array($value  ,  $vars   );数组问  :    既然在的话,告诉我你在哪
$key  array_search(&value , $vars);数组问  :    呢给我看看你们的地址簿吧
$keys = array_keys($vars);     //返回键值数组

print_r($keys);数组问  :    都住的谁啊?
$values= array_keys($vars);     //返回键值数组

当索引不是数字的时候,我一直使用的for(int i=0;;i++)下岗了…

//返回key的
while(  $key=key($vars)  )   
{   
    next($vars);
}
//返回value的
while(  $value=current($vars)  )   
{
    next($vars);
}
取next()的方法不错,还可以继续定位~
$value prev($vars)   //前一个

$value reset($vars)   //起点

$value end($vars)   //终点 全面的看数组
总共多大?
Int count($vars)   //返回数组大小
//递归计数:
Int count($vars , 1); //第二参数是模式选择每个种类出现几次?求频率~
$vars_f array_count_values($vars); 我只想知道有几类!去除重复
$vars_u array_unique($vars); 整理一下在看
从小到大按ASCII码顺序排好(默认的,可以选择)
sort($vars);   //基本排序你排完的key值咋变了
asort($vars);      //键值不改变的排序从大到小难道只能反着看?
resort($vars)    //a1--a10-a2好,还是a1-a2-a10好?  自然排序
natsort($vars)不要因为大小写忽略排序美感
natcasesort($vars)不会只能按内容排列吧?  key排序
?ksort();

到了DIY的时候了~
usort ($vars , 'myFunction');
//myFun()的返回:小于-负数 , 等于-0 , 大于-正数

这数组结构不行,我要改改!
合并 :
array_merge(&vars1 , $vars2);递归着合并 :
array_merge_recursive(&vars1 , $vars2);
//递归的时候会将一样value值的合并成数组追加
array_combine(&vars1 , $vars2);连接
array_merge(&vars1 , $vars2);划分1:
$vars_r = array_slice($vars , 4);//去掉前四个划分2:
$vars_r = array_slice($vars ,2,-2);//去掉前2个,后2个      划分原数组不变

拆分
$vars_r = array_slice($vars , 4 ,-2);      原数组$vars,保留前4个

      返回的$vars_r拥有后2个

交集:
$vars_r = array_intersect($vars1 , $vars2 ,$vars3);差集:第一个有,其他没有的
$vars_r = array_diff($vars1 , $vars2 ,$vars3);数组元素的洗牌~ :
Shuffle($vars);求和
$sum = array_sum($vars);

 


摘自 matter605924657

www.bkjia.comtruehttp://www.bkjia.com/PHPjc/478243.htmlTechArticle函数是每个编程语言必不可少的,我得了解了PHP有什么不同 最犀利的就是返回类型,不用在函数声明注明 唯一需要注意的是你得用对应的类型...
Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn