array_key_exists() 함수는 지정된 키가 배열에 존재하는지 확인합니다. 키가 존재하면 true를 반환하고, 그렇지 않으면 false를 반환합니다.
array_key_exists(key,array);
키: 필수입니다. 키 이름
배열 지정: 필수. 입력 배열 지정
<?php $a = array('a'=>'Dog','b'=>'Cat'); if(array_key_exists('a',$a)){ echo 'Key exists!'; } else{ echo 'Key does not exist!'; } ?>
출력: 키가 있습니다!
array_key_exists가 in_array보다 빠른 이유는 무엇입니까?
그리고 in_array는 루프에서 벗어나기 전에 값을 순회해야 합니다.
질문:
인덱스
가 별도의 저장 장치인가요? optimized, array_key_exists 시간 복잡도는 o(1)이고, in_array는 o(n) ??
후속 답변: 복잡도 측면에서 보면 그렇습니다
array_key_exists는 특정을 판단하는 것입니다. 각 키에 값이 있습니까?
in_array 동일한지 확인하기 위해 한 번 순회하고 싶은데 구성을 모르면 순회해야 합니다
PHP에서 isset과 array_key_exists의 차이점
1. 배열 값의 경우 판단이 다릅니다. 값이 null이거나 ''이거나 false이면 isset은 false를 반환하고 array_key_exists는 true를 반환합니다.
2. 실행 효율성이 다릅니다. isset은 내장 연산자이고, array_key_exists는 PHP 내장 함수이며, isset이 더 빠릅니다. PHP 함수 구현 원리 및 성능 분석
을 참조하세요. 3. 존재하지 않는
인덱스배열 값에 액세스하기 위해 isset을 사용할 때 E_NOTICE php 오류 메시지가 발생하지 않습니다.
4.array_key_exists는 get_define_vars를 호출하여 배열 변수가 존재하는지 확인하고 isset은 사용되지 않습니다. 테스트 코드:
위 내용은 인덱싱을 포함한 PHP 배열 함수 array_key_exists에 대한 요약입니다. PHP 튜토리얼에 관심이 있는 친구들에게 도움이 되길 바랍니다.
<?php function microtime_float() { list($usec, $sec) = explode(" ", microtime()); return ((float)$usec + (float)$sec); } $test_arr['aa']='dd'; $test_arr['bb']=''; $test_arr['cc']=NULL; $test_arr['dd']=false; $test_arr= array('aa'=>'dd','bb'=>'','cc'=>null,'dd'=>false); echo "isset aa is ";var_dump(isset($test_arr['aa']));echo "n"; echo "isset bb is ";var_dump(isset($test_arr['bb']));echo "n"; echo "isset cc is ";var_dump(isset($test_arr['cc']));echo "n"; echo "isset dd is ";var_dump(isset($test_arr['cc']));echo "n"; echo "isset none is ";var_dump(isset($test_arr['none']));echo "n"; echo "key_exist aa is ";var_dump(array_key_exists('aa',$test_arr));echo "n"; echo "key_exist bb is ";var_dump(array_key_exists('bb',$test_arr));echo "n"; echo "key_exist cc is ";var_dump(array_key_exists('cc',$test_arr));echo "n"; echo "key_exist dd is ";var_dump(array_key_exists('dd',$test_arr));echo "n"; echo "key_exist none is ";var_dump(array_key_exists('none',$test_arr));echo "n"; $time_start = microtime_float(); for($i=0;$i<100;$i++){ isset($test_arr['aa']); } $time_end = microtime_float(); $time = $time_end - $time_start; echo "isset 100 is $timen"; for($i=0;$i<10000;$i++){ isset($test_arr['aa']); } $time_end = microtime_float(); $time = $time_end - $time_start; echo "isset 10000 is $timen"; for($i=0;$i<1000000;$i++){ isset($test_arr['aa']); } $time_end = microtime_float(); $time = $time_end - $time_start; echo "isset 1000000 is $timen"; //++++++++++++++++++++++++++++++ $time_start = microtime_float(); for($i=0;$i<100;$i++){ array_key_exists('aa',$test_arr); } $time_end = microtime_float(); $time = $time_end - $time_start; echo "array_key_exists 100 is $timen"; for($i=0;$i<10000;$i++){ array_key_exists('aa',$test_arr); } $time_end = microtime_float(); $time = $time_end - $time_start; echo "array_key_exists 10000 is $timen"; for($i=0;$i<1000000;$i++){ array_key_exists('aa',$test_arr); } $time_end = microtime_float(); $time = $time_end - $time_start; echo "array_key_exists 1000000 is $timen";