$arr = array(0=>1,"aa"=>2, 3, 4);

foreach($arr as $key=>$val){
print($key == "aa" ? " /> 国产精品69久久久久水密桃,91国偷自产一区二区三区亲奶,3bmm在线观看视频免费

中文字幕日韩一区二区_国产一区二区av_国产毛片av_久久久久国产一区_色婷婷电影_国产一区二区精品

幾道坑人的PHP面試題 試試看看你會不會也中招

這幾道題是在德問上看到的,感覺挺有意思,拿來給大家分享其中的陷阱,看看你會不會掉入其中。

第一題

復制代碼 代碼如下:
$arr = array(0=>1,"aa"=>2, 3, 4);
 
foreach($arr as $key=>$val){
    print($key == "aa" ? 5 : $val);
}
輸出結果是多少?如果的答案是1534就掉入陷阱了。
先看看這個數(shù)組最終形成的結構:
復制代碼 代碼如下:
Array
(
    [0] => 1
    [aa] => 2
    [1] => 3
    [2] => 4
)
然后遍歷每一個元素的key看等不等于aa,等于就用5替代。當我告訴你答案是5534的時候,你會不會有點驚訝!難道0等于"aa"嗎?是的,0就等于"aa",這道題重點就考你這個。在php中兩個值進行邏輯判斷時,如果兩個值的類型不一致php會自動把右邊的值轉(zhuǎn)換到左邊的類型,然后再進行判斷。因此"aa"轉(zhuǎn)換整形等于0,自然也就等于左邊的0了。你可以使用全等于避免這種該情況,也就是如果你寫成:
復制代碼 代碼如下:
print($key === "aa" ? 5 : $val);
那么答案就是1534了。

第二題

復制代碼 代碼如下:
$i='11';
printf("%d/n",printf("%d",printf("%d",$i)));
輸出結果是多少?如果你回答是11,或者111111就掉入陷阱了。
先了解printf這個函數(shù),printf不僅是打印函數(shù),它還有返回值。重點就在這
復制代碼 代碼如下:
var_dump(printf("%d",$i));
你猜猜上面的結果是啥?先是printf打印變量本身11,然后printf會返回一個變量字符串長度的值,11有兩個字符,于是返回2,于是上面語句的執(zhí)行結果等于:
復制代碼 代碼如下:11int(2)
清楚了這一點以后,再回過來看上面的試題,按照優(yōu)先級,限制性深度printf函數(shù),打印11,返回2。接著到第二級printf函數(shù),打印2,返回1。最后到第三層,直接打印1,所以執(zhí)行結果是 1121。

第三題

復制代碼 代碼如下:
$a = 3;
$b = 5;
if($a = 5 || $b = 7) {
    $a++;
    $b++;
}
echo $a . " " . $b;
執(zhí)行結果是多少?如果你回答 6 8 or 4 6 or  6 6,那你就掉入陷阱了。
第一個陷阱,認為答案等于 4 6 。估計你粗心把  $a = 5 ||  $b = 7  看成 $a == 5 ||  $b == 7 ,這是新手常犯的錯誤。

第二個陷阱,認為答案等于 6 8。 你識破了  $a = 5 ||  $b = 7 這個騙局,但你沒有注意到,邏輯或里只要依次執(zhí)行直到某個表達式結果為true,表達式后邊的就不再執(zhí)行,$a = 5 返回true,后邊的$b=7就不執(zhí)行了。
第三個陷阱,認為答案等于 6 6。 OK,你識破了 邏輯或的規(guī)則,于是$a=5執(zhí)行,$b=7不執(zhí)行,但是你沒有考慮到這里是邏輯表達式,返回給$a的值是要轉(zhuǎn)換為布爾值的。這樣看。

所以經(jīng)過以上三個陷阱,你應該知道答案是多少了,其實 $a等于true以后,echo $a 輸出就是1 ,$b值不變,結果就是 1 6 。

第四題

復制代碼 代碼如下:
$count = 5;
function get_count() {
    static $count = 0;
    return $count++;
}
++$count;
get_count();
echo get_count();
執(zhí)行結果是多少?如果你回答 2 ,恭喜,你掉入陷阱了。
其實這道題主要考兩點,第一點是static靜態(tài)類型。這種的值永遠都是靜態(tài)的,第一次調(diào)用聲明等于0,并且自增等于1。第二次調(diào)用,1再自增就等于2。但其實這里還有一道陷阱,那就是++a與a++的區(qū)別,前++是先自增,后++是先返回值再自增,所以結果等于 1。

第五題

復制代碼 代碼如下:
$a = count ("567")  + count(null) + count(false);
echo $a;

如果你回答 3 or 1,恭喜,掉入陷阱了。
因為count(null)等于0,false也算一個值。所以count(false)等于1。

php技術幾道坑人的PHP面試題 試試看看你會不會也中招,轉(zhuǎn)載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 成人精品一区 | 国产精品福利在线观看 | 亚洲一区二区久久久 | 免费v片在线观看 | 人人九九精| 午夜免费在线电影 | av大片| 91视视频在线观看入口直接观看 | 欧美精品1区2区 | 9999国产精品欧美久久久久久 | 四虎成人精品永久免费av九九 | 亚洲欧美国产精品久久 | 成人精品鲁一区一区二区 | 亚洲图片一区二区三区 | 久久久久9999亚洲精品 | 久久久免费在线观看 | 国产精品精品视频一区二区三区 | 日韩激情视频一区 | 欧美精品网站 | 欧美日韩不卡 | 精品久久久久久久久久久久 | 国产一区二区三区在线免费观看 | 欧美亚洲日本 | 精品欧美一区二区三区 | 91精品国产777在线观看 | 成人欧美一区二区三区在线观看 | 精品在线一区二区 | 手机看片在线播放 | 在线成人福利 | 在线播放一区二区三区 | 成人在线中文字幕 | 自拍偷拍3p | 天天干天天色 | 精品久久久久久久久久久久 | 99视频在线 | 久久久片| 新91视频网| 日韩高清成人 | 91成人精品 | 成人免费淫片aa视频免费 | 午夜久久久 |