이 기사에서는 주로 PHP가 빠질 수 있는 함정을 공유합니다. 모든 사람에게 도움이 되기를 바라며 작은 예를 통해 답변을 공유합니다.
오늘 질문을 받았습니다:
$var = 'test'; if (isset($var['somekey'])) { echo 'reach here!!!'; }
'reach here!!!'가 출력되나요? ---당연하지. 나는 별 생각 없이 대답했다.
역시 함정에 빠졌어요! 출력됩니다! 함정에 빠지지 않았다면 축하합니다. 아래를 내려다 볼 필요는 없습니다.
이제 분석해 보겠습니다. 이제 isset이 설정되었으니 값은 무엇인가요? 인쇄해 보겠습니다.
var_dump($var['somekey']); //=>output: string(1) "t"
는 $var의 첫 번째 문자인 't'입니다.
$var 변수는 문자열이기 때문에 C 언어를 배웠다면 char형 배열이라는 것을 알 수 있을 것이므로 $var[0] $var[1] $var[$i]를 사용할 수 있습니다. ... 얻으려면 $var의 $i+1번째 문자입니다. 그렇다면 'somekey'는 왜 첫 번째 문자를 얻었습니까? 이는 PHP가 여기서 암시적 유형 변환을 수행하여 여기의 문자열을 int 유형으로 변환하기 때문입니다. intval('somekey') 함수를 사용해 본 경우 얻는 값이 0이라는 것을 알 수 있으므로 $var['somekey']결국 $var[0]입니다. 드디어 't'를 얻었습니다.
위 내용은 PHP가 빠질 수 있는 함정 1의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!