在PHP应用中,数组是用得最广泛的数据结构了。基本可以这么说,熟练掌握数组你就可以熟练掌握PHP的大部分了。下面将PHP的数组操作进行汇总介绍下,或许有你不懂或不怎么了解的数组操作。
将数组的内部指针倒回一位:
/** * 将数组的内部指针倒回一位 * @param array &$arr * @return mixed 返回前一个单元的值,当没有更多单元时返回 FALSE * 如果数组包含空的单元,或者单元的值是 0 则本函数碰到这些单元也返回 FALSE * 要正确遍历可能含有空单元或者单元值为 0 的数组,参见 each() 函数 */ mixed prev(array &$arr); <?php $transport = array('foot', 'bike', 'car', 'plane'); $mode = current($transport); // $mode = 'foot'; $mode = next($transport); // $mode = 'bike'; $mode = next($transport); // $mode = 'car'; $mode = prev($transport); // $mode = 'bike'; $mode = end($transport); // $mode = 'plane'; $mode = reset($transport) ;//$mode = 'foot'; ?>
把数组中的单元转换为变量:
array("key"=>"value");建立数组 //显示数组 print_r($array); //使用compact()函数新建数组,并把参数做为新数组的单元; $newArray = compact("red","green","yellow","blue","array"); //使用extract()函数把数组中的单元转换为变量 extract($exArray); echo "$key1 $key2 $key3 $key4 $key5";
检查值、键:
array_key_exists($key,$array);//检查数组键 in_array($value,$array);//检查值于数组
获取值:
//使用array_values()取得数组的值 $carValues = array_values($car); //取出数组的键名 $twoKeys = array_keys($two); key($array);//输出当前单元的键名 //数组定义后,使用current()取得当前单元的值 $red = current($array); list($red,$green) = $array;//把数组中的值赋与变量,$array = array("红色","绿色"); each($two);//返回数组中当前单元的键和值
遍历数组:
foreach($two as $subArray);//遍历数组 while(list($key,$value) = each($array)){ echo "$key=>$value,";//使用each遍历数组 }
填充数组:
//向左、右填充数组 array_pad($array,+3,"shuzhi");//2参数为正从左往右填充,数值大于单元数时才填充 $array1 = array_fill(5,5,"test");//使用array_fill()填充这个数组的值,值为test,从第5个单元开始填充,一共填充5个单元 //填充数组键名 $keys = array('string', 5, 10, 'str'); $array3 = array_fill_keys($keys,"数组值"); //使用array_filp()函数交换键名与值 $speed = array_flip($speed); //使用array_splice()函数替换第6个单元的值为7 $output = array_splice($input,6,0,7); //使用array_splice()函数删除数组单元,只保留前5个单元 $output = array_splice($input,5); $array1 = range(10,100,10); //使用range()函数的第三个参数,设置单元之间的步进值
排序:
shuffle($array);//将数组顺序打乱 //使用array_multisort()对三个数组排序 array_multisort($sort1,$sort2,$sort3); //把这个数组进行排序,并保持索引关系 asort($array); //把测试数组进行逆向排序,并保持索引关系 arsort($array); //使用ksort()对数组按键名排序 ksort($array); //使用krsort()函数按键名逆向排序 krsort($array); //使用sort()对测试数组进行排序[以键名排列] sort($array); //使用natsort()排序[自然排序,以数值排列]对单元数值大小写敏感 natsort($array); //使用natcasesort()函数排序[自然排序]但是忽略数值大小写 natcasesort($array); //使用array_reverse()函数排序,数组单元按相反排列 $newArray = array_reverse($array,TRUE);//TRUE设时保留原键名
交集、差集:
//使用array_diff()计算三个数组的差集[对数组数值比较] $result = array_diff($dog1,$dog2,$dog3); //使用array_diff_assoc()计算三个数组的差集[对数值和键名比较] $result = array_diff_assoc($dog1,$dog2,$dog3); //使用array_diff_key()计算三个数组的差集[比较键名] $result = array_diff_key($dog1,$dog2,$dog3); //使用array_intersect()计算三个数组的交集[对数组数值比较] $result = array_intersect($dog1,$dog2,$dog3); //使用array_intersect_assoc()计算三个数组的交集[对数值和键名比较] $result = array_intersect_assoc($dog1,$dog2,$dog3); //使用array_intersect_key()计算三个数组的交集[比较键名] $result = array_intersect_key($dog1,$dog2,$dog3);
合并数组:
//使用array_merge()函数合并数组 $result = array_merge($array1,$array2,$array3,$array4,$array5); array_rand($input,10);//随机取出10个单元 count($array,COUNT_RECURSIVE);//显示数组单元数目,2参数只可为1或者COUNT_RECURSIVE,有时可遍历多维数组
出入栈:
//数组出栈,后进先出,数组最后一个单元弹出 array_pop($array); //数组入栈,将7,8两个数值添加到数组尾部 array_push($array,7,8); //将数组开头单元移出数组 array_shift($array); //将7,8添加入数组开头 array_unshift($array,7,8);

aphpdectionenceindectioncontainerisatoolthatmanagesclassdependencies, 향상 Codemodularity, testability 및 maintainability.itactAsacentralHubForCreatingAndingDinjectingDingingDingingdecting.

대규모 응용 프로그램의 경우 SELLENCIONINGESS (DI)를 선택하십시오. ServicElocator는 소규모 프로젝트 또는 프로토 타입에 적합합니다. 1) DI는 생성자 주입을 통한 코드의 테스트 가능성과 모듈성을 향상시킵니다. 2) Servicelocator는 센터 등록을 통해 서비스를 얻습니다. 이는 편리하지만 코드 커플 링이 증가 할 수 있습니다.

phPapplicationSCanBeoptimizedForsPeedandefficiencyby : 1) ENABLEOPCACHEINPHP.INI, 2) PREPAREDSTATEMENTSWITHPDOFORDATABASEQUERIES 사용

phpeMailValidationInvoLvestHreesteps : 1) formatValidationUsingRegularexpressionsTochemailformat; 2) dnsValidationToErethedomainHasaValidMxRecord; 3) smtpvalidation, theSTHOROUGHMETHOD, theCheckSiftheCefTHECCECKSOCCONNECTERTETETETETETETWERTETWERTETWER

TomakePhPapplicationSfaster, followthesesteps : 1) useopCodeCaching likeOpcachetOrpectipiledScriptBecode.2) MinimizedAtabaseQueriesByUsingQueryCachingandEfficientIndexing.3) leveragephp7 assistorBetterCodeeficiession.4) 구현 전략적 지시

toImprovePhPapplicationSpeed, followthesesteps : 1) enableOpCodeCachingWithApcuTeCeScripteXecutionTime.2) 구현 구현

의존성 주입 (DI)은 명시 적으로 전이적 종속성에 의해 PHP 코드의 테스트 가능성을 크게 향상시킵니다. 1) DI 디퍼 커플 링 클래스 및 특정 구현은 테스트 및 유지 보수를보다 유연하게 만듭니다. 2) 세 가지 유형 중에서, 생성자는 상태를 일관성있게 유지하기 위해 명시 적 표현 의존성을 주입합니다. 3) DI 컨테이너를 사용하여 복잡한 종속성을 관리하여 코드 품질 및 개발 효율성을 향상시킵니다.

DatabaseQuesyOptimizationInphPinVolvesVesstoigiestoInsperferferferferformance.1) SelectOnlyNecessaryColumnstoredAtatatransfer.2) useinDexingTeSpeedUpdatarretieval.3) ubstractOrerEresultSoffRequeries.4) UtilizePreDstatements Offeffi


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

ZendStudio 13.5.1 맥
강력한 PHP 통합 개발 환경

SecList
SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.

Dreamweaver Mac版
시각적 웹 개발 도구

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.