文章所羅列的PHP 面試問題雖然看似簡單,但是每個背後都涵蓋了一個或幾個大家容易忽視的基礎知識點,希望能夠幫助到你的面試和平時工作。
第一個問題關於弱類型
$str1 ='yabadabadoo';
$str2 ='yaba';
if(strpos($str1,$str2)){
echo"\"". $str1 ."\" contains \"". $str2 ."\"";
}else{
echo"\"". $str1 ."\" does not contain \"". $str2 ."\"";
}
正確運行的輸出結果:
"yabadabadoo" does not contain "yaba"
strpos
是返回字符串str2
在str1
的位置,沒有找到則返回false
然而實際上這次返回了0
而在if語句中0也被當作false,所以我們需要對false做類型判斷,正確的代碼如下:
$str1 ='yabadabadoo';
$str2 ='yaba';
if(strpos($str1,$str2)!==false){
echo"\"". $str1 ."\" contains \"". $str2 ."\"";
}else{
echo"\"". $str1 ."\" does not contain \"". $str2 ."\"";
}
需要注意的是我們使用了!==
,在php 和 JS中= !
相對==
更為嚴格需要要求數據類型一致。
下面的輸出結果會是怎樣?
$x =5;
echo $x;
echo"<br />";
echo $x+++$x++;
echo"<br />";
echo $x;
echo"<br />";
echo $x---$x--;
echo"<br />";
echo $x;
實際運行結果是
5
11
7
1
5
關於 $x++
和 $x--
這個問題其實非常容易遇見,我們只需記住$x++
使用最近的值,然後才自增。
運算符的優先級,++
是明顯高於 +
,因此先執行++ 再執行 + 。關於運算符的優先級,有的時候我們真的可以通過括號來讓我們的程序更讓人直觀的了解,畢竟代碼不光是用於執行的,有的時候或許團隊的可讀性也是提高效率的一種。
關於變量的引用;
$a ='1';
$b =&$a;
$b ="2$b";
請問 $a
和 $b
的值各位多少
部分第一時間會想到 $a='1' $b='21'
,仔細一看 $b=&$a
,這裡$b
是變量$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(1)[1]=>int(2)}
NULL
NULL
運行的時候你或許還能看到下面的警告
Warning: array_merge():Argument#2isnot an array
Warning: array_merge():Argument#1isnot an array
array_merge
需要傳入的參數都是數組,如果不是,則會返回null。 你可以這樣修改
$testArray = array_merge($testArray,(array)$referenceTable['val1']);
var_dump($testArray);
$testArray = array_merge($testArray,(array)$referenceTable['val2']);
var_dump($testArray);
$testArray = array_merge($testArray,(array)$referenceTable['val3']);
var_dump($testArray);
$x應該是輸出什麼?
$x =trueandfalse;
var_dump($x);
部分同學或許會第一時間想到false,實際上這裡依舊是強調運算符的優先級,= 會比 and級別高點,因此等同下面的代碼
$x =true;
trueandfalse
答案顯而易見。
經過下面的運算 $x的值應該是多少?
$x =3+"15%"+"$25"
答案是18
,PHP是會根據上下文實現類型的自動轉換
上面的代碼我們可以這樣理解,如果我們在與字符串進行數學運算,實際php會盡可能將字符串中的數組進行轉換,如果是數字開頭的話則轉換成改數字比如"15%"會變成15,如果不是數字開頭則會變成0; 上面的運算類似下面 :
$x =3+15+0
運行下面的代碼,$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