Cet article partage avec vous le contenu de 10 questions d'entretien sur PHP. Les amis dans le besoin peuvent s'y référer
La première question concerne 弱类型
$str1 ='yabadabadoo'; $str2 ='yaba'; if(strpos($str1,$str2)){ echo"\"". $str1 ."\" contains \"". $str2 ."\""; }else{ echo"\"". $str1 ."\" does not contain \"". $str2 ."\""; }
Résultat de sortie du bon fonctionnement :
<span class="str">"yabadabadoo"</span><span class="pln"> does </span><span class="kwd">not</span><span class="pln"> contain </span><span class="str">"yaba"</span>
strpos
renvoie la chaîne str2
à la position de str1
Si elle n'est pas trouvée, elle renvoie false
. cette fois, 0
est renvoyé et 0 est également traité comme faux dans l'instruction if, nous devons donc faire un jugement de type sur false. Le code correct est le suivant :
$str1 ='yabadabadoo'; $str2 ='yaba'; if(strpos($str1,$str2)!==false){ echo"\"". $str1 ."\" contains \"". $str2 ."\""; }else{ echo"\"". $str1 ."\" does not contain \"". $str2 ."\""; }
En PHP et JS, !==
est plus strict que = !
et nécessite des types de données cohérents. ==
$x =5; echo $x; echo"<br />"; echo $x+++$x++; echo"<br />"; echo $x; echo"<br />"; echo $x---$x--; echo"<br />"; echo $x;
<span class="lit">5</span>
<span class="lit">11</span>
<span class="lit">7</span>
<span class="lit">1</span>
<span class="lit">5</span>
et $x++
, ce problème est en fait très facile à rencontrer. Il suffit de rappeler que $x--
utilise la dernière valeur puis l'incrémente. La priorité de l'opérateur $x++
est nettement supérieure à ++
, donc ++ est exécuté en premier, puis + . Concernant la priorité des opérateurs, nous pouvons parfois vraiment utiliser des parenthèses pour rendre notre programme plus intuitif à comprendre. Après tout, le code n'est pas seulement utilisé pour l'exécution. Parfois, la lisibilité de l'équipe peut également améliorer l'efficacité. +
$a ='1'; $b =&$a; $b ="2$b";
et $a
Pour la partie $b
Regardez de plus près $a='1' $b='21'
Ici, $b=&$a
est une référence à la variable $b
. plutôt qu'une affectation directe. $a
下面是true还是false
var_dump(0123==123); var_dump('0123'==123); var_dump('0123'===123); var_dump(0123 == 123);// false,PHP会默认把0123当作8进制来处理,实际转化为10进制就是83,显然这不是相等的。 var_dump('0123' == 123);// true这里php会非常有趣的将'0123'转换成一个数字而且默认去掉了前面的0也就是123==123 var_dump('0123' === 123);// false很显然上面的问题已经说过了数字和字符串类型不一致。
下面的代码有什么问题吗?输出会是什么,怎样修复它
$referenceTable =array(); $referenceTable['val1']=array(1,2); $referenceTable['val2']=3; $referenceTable['val3']=array(4,5); $testArray =array(); $testArray = array_merge($testArray, $referenceTable['val1']); var_dump($testArray); $testArray = array_merge($testArray, $referenceTable['val2']); var_dump($testArray); $testArray = array_merge($testArray, $referenceTable['val3']); var_dump($testArray);
实际输出如下:
array(2){[0]=>int(<span class="lit">1</span>)[<span class="lit">1</span>]=>int(2)}
<span class="pln">NULL</span>
<span class="pln">NULL</span>
运行的时候你或许还能看到下面的警告
<span class="typ">Warning</span><span class="pun">:</span><span class="pln"> array_merge</span><span class="pun">():</span><span class="typ">Argument</span><span class="com">#</span><span class="lit">2</span><span class="kwd">is</span><span class="kwd">not</span><span class="pln"> an </span><span class="kwd">array</span>
Warning: array_merge():Argument#<span class="lit">1</span>isnot an array
array_merge
需要传入的参数都是数组,如果不是,则会返回null。 你可以这样修改
<span class="pln">$testArray </span><span class="pun">=</span><span class="pln"> array_merge</span><span class="pun">(</span><span class="pln">$testArray</span><span class="pun">,</span><span class="pun">(</span><span class="kwd">array</span><span class="pun">)</span><span class="pln">$referenceTable</span><span class="pun">[</span><span class="str">'val1'</span><span class="pun">]);</span>
<span class="pln">var_dump</span><span class="pun">(</span><span class="pln">$testArray</span><span class="pun">);</span>
<span class="pln">$testArray </span><span class="pun">=</span><span class="pln"> array_merge</span><span class="pun">(</span><span class="pln">$testArray</span><span class="pun">,</span><span class="pun">(</span><span class="kwd">array</span><span class="pun">)</span><span class="pln">$referenceTable</span><span class="pun">[</span><span class="str">'val2'</span><span class="pun">]);</span>
<span class="pln">var_dump</span><span class="pun">(</span><span class="pln">$testArray</span><span class="pun">);</span>
<span class="pln">$testArray </span><span class="pun">=</span><span class="pln"> array_merge</span><span class="pun">(</span><span class="pln">$testArray</span><span class="pun">,</span><span class="pun">(</span><span class="kwd">array</span><span class="pun">)</span><span class="pln">$referenceTable</span><span class="pun">[</span><span class="str">'val3'</span><span class="pun">]);</span>
<span class="pln">var_dump</span><span class="pun">(</span><span class="pln">$testArray</span><span class="pun">);</span>
$x应该是输出什么?
$x =trueandfalse; var_dump($x);
部分同学或许会第一时间想到false,实际上这里依旧是强调运算符的优先级,= 会比 and级别高点,因此等同下面的代码
<span class="pln">$x </span><span class="pun">=</span><span class="kwd">true</span><span class="pun">;</span>
<span class="kwd">true</span><span class="kwd">and</span><span class="kwd">false</span>
答案显而易见。
经过下面的运算 $x的值应该是多少?
$x =3+"15%"+"$25"
答案是18
,PHP是会根据上下文实现类型的自动转换
上面的代码我们可以这样理解,如果我们在与字符串进行数学运算,实际php会尽可能将字符串中的数组进行转换,如果是数字开头的话则转换成改数字比如"15%"会变成15,如果不是数字开头则会变成0; 上面的运算类似下面 :
<span class="pln">$x </span><span class="pun">=</span><span class="lit">3</span><span class="pun">+</span><span class="lit">15</span><span class="pun">+</span><span class="lit">0</span>
运行下面的代码,$text
的值是多少?strlen($text)
又会返回什么结果?
$text ='John '; $text[10]='Doe';
上面代码执行完毕后 $text = "John D"
(John后面会有连续的5个空格) strlen($text)
会返回11
$text[10] = "Doe"
给某个字符串具体的某个位置具体字符时候,实际只会把D赋给$text
. 虽然$text
才开始只有5个自负长度,但是php会默认填充空格。这和别的语言有些差别。
下面的输出结果会是什么
$v =1; $m =2; $l =3; if( $l > $m > $v){ echo"yes"; }else{ echo"no"; }
实际的输出是"no",只要仔细分析就不难得出
$l>$m
会转换成1 ,则这个时候再和$m比较。
执行下面代码$x
会变成什么值呢?
$x = NULL; if('0xFF'==255){ $x =(int)'0xFF'; }
实际的运行结果是
$x=0
而不是255.
首先'oxFF' == 255
我们好判断,会进行转换将16进制数字转换成10进制数字,0xff -> 255.
PHP使用is_numeric_string
判断字符串是否包含十六进制数字然后进行转换。
但是$x = (int)'0xFF';
是否也会变成255呢?显然不是,将一个字符串进行强制类型转换实际上用的是convert_to_long
,它实际上是将字符串从左向右进行转换,遇到非数字字符则停止。因此0xFF
到x就停止了。所以$x=0
相关推荐:
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!