文章所羅列的問題雖然看似簡單,但是每個背後都涵蓋了一個或幾個大家容易忽視的基礎知識點,希望能夠幫助到你的面試和平時工作。
Q1
第一個問題關於弱類型
$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中= !相對== 更為嚴格需要要求數據類型一致。
Q2
下面的輸出結果會是怎樣?
$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++使用最近的值,然後才自增。
運算符的優先級,++ 是明顯高於 +,因此先執行++ 再執行 + 。關於運算符的優先級,有的時候我們真的可以通過括號來讓我們的程序更讓人直觀的了解,畢竟代碼不光是用於執行的,有的時候或許團隊的可讀性也是提高效率的一種。
Q3
關於變量的引用;
$a = '1'; $b = &$a; $b = "2$b";
請問 $a 和 $b的值各位多少
部分第一時間會想到 $a='1′ $b='21′,仔細一看 $b=&$a,這裡$b是變量$a的引用而不是直接 賦值。
Q4
下面是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很顯然上面的問題已經說過了數字和字符串類型不一致。
Q5
下面的代碼有什麼問題嗎?輸出會是什麼,怎樣修復它
$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 #2 is not an array
Warning: array_merge(): Argument #1 is not 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);
Q6
$x應該是輸出什麼?
$x = true and false; var_dump($x);
部分同學或許會第一時間想到false,實際上這裡依舊是強調運算符的優先級,= 會比 and級別高點,因此等同下面的代碼
$x = true; true and false
答案顯而易見。
Q7
經過下面的運算 $x的值應該是多少?
$x = 3 + "15%" + "$25"
答案是18,PHP是會根據上下文實現類型的自動轉換
上面的代碼我們可以這樣理解,如果我們在與字符串進行數學運算,實際php會盡可能將字符串中的數組進行轉換,如果是數字開頭的話則轉換成改數字比如”15%”會變成15,如果不是數字開頭則會變成0; 上面的運算類似下面 :
$x = 3 + 15 + 0
Q8
運行下面的代碼,$text 的值是多少?strlen($text)又會返回什麼結果?
$text = 'John '; $text[10] = 'Doe';
上面代碼執行完畢後 $text = “John D”(John後面會有連續的5個空格) strlen($text)會返回11
$text[10] = “Doe”給某個字符串具體的某個位置具體字符時候,實際只會把D賦給$text. 雖然$text才開始只有5個自負長度,但是php會默認填充空格。這和別的語言有些差別。
Q9
下面的輸出結果會是什麼
$v = 1; $m = 2; $l = 3; if( $l > $m > $v){ echo "yes"; }else{ echo "no"; }
實際的輸出是”no”,只要仔細分析就不難得出
$l>$m 會轉換成1 ,則這個時候再和$m比較。
Q10
執行下面代碼$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
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持。