>  기사  >  백엔드 개발  >  PHP가 빠질 수 있는 함정 1

PHP가 빠질 수 있는 함정 1

小云云
小云云원래의
2018-03-19 14:57:531222검색

이 기사에서는 주로 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.