10個問題,看似簡單,但是每個背后都涵蓋了一個或幾個大家容易忽視的基礎(chǔ)知識點,希望能夠幫助到你的面試和平時工作。
Q1第一個問題關(guān)于 弱類型
- <?php
- $str1 = 'yabadabadoo';
- $str2 = 'yaba';
- if (strpos($str1,$str2)) {
- echo "\"" . $str1 . "\" contains \"" . $str2 . "\"";
- } else {
- echo "\"" . $str1 . "\" does not contain \"" . $str2 . "\"";
- }
復制代碼
正確運行的輸出結(jié)果:
- "yabadabadoo" does not contain "yaba"
復制代碼
strpos 是返回字符串 str2 在 str1 的位置,沒有找到則返回 false ,然而實際上這次返回了 0 而在if語句中0也被當作false,所以我們需要對false做類型判斷,正確的代碼如下:
- <?php
- $str1 = 'yabadabadoo';
- $str2 = 'yaba';
- if (strpos($str1,$str2) !== false) {
- echo "\"" . $str1 . "\" contains \"" . $str2 . "\"";
- } else {
- echo "\"" . $str1 . "\" does not contain \"" . $str2 . "\"";
- }
復制代碼
需要注意的是我們使用了 !== ,在php 和 JS中 != 相對== 更為嚴格需要要求數(shù)據(jù)類型一致.
Q2 :下面的輸出結(jié)果會是怎樣?
- <?php
- $x = 5;
- echo $x;
- echo "<br />";
- echo $x+++$x++;
- echo "<br />";
- echo $x;
- echo "<br />";
- echo $x---$x--;
- echo "<br />";
- echo $x;
復制代碼
實際運行結(jié)果是:
關(guān)于 $x++ 和 $x-- 這個問題其實非常容易遇見,我們只需記住 $x++ 使用最近的值,然后才自增。運算符的優(yōu)先級, ++ 是明顯高于 + ,因此先執(zhí)行++ 再執(zhí)行 + 。關(guān)于運算符的優(yōu)先級,有的時候我們真的可以通過括號來讓我們的程序更讓人直觀的了解,畢竟代碼不光是用于執(zhí)行的,有的時候或許團隊的可讀性也是提高效率的一種。
Q3:關(guān)于變量的引用;
- <?php
- $a = '1';
- $b = &$a;
- $b = "2$b";
復制代碼
請問 $a 和 $b 的值各位多少?
部分第一時間會想到 $a='1' $b='21' ,仔細一看 $b=&$a ,這里 $b 是變量 $a 的引用,而不是直接賦值。
Q4:下面是true還是false
- <font size="2"><?php
- var_dump(0123 == 123);
- var_dump('0123' == 123);
- var_dump('0123' === 123);</font>
復制代碼
var_dump(0123 == 123);// false ,PHP會默認把0123當作8進制來處理,實際轉(zhuǎn)化為10進制就是83,顯然這不是相等的。
var_dump('0123' == 123);// true 這里php會非常有趣的將'0123'轉(zhuǎn)換成一個數(shù)字而且默認去掉了前面的0也就是 123==123
var_dump('0123' === 123);// false 很顯然上面的問題已經(jīng)說過了數(shù)字和字符串類型不一致。
Q5:下面的代碼有什么問題嗎?輸出會是什么,怎樣修復它
- <font size="2"><?php
- $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); </font>
復制代碼
實際輸出如下:
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 需要傳入的參數(shù)都是數(shù)組,如果不是,則會返回null。 你可以這樣修改
- <?php
- $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應(yīng)該是輸出什么?
- <?php
- $x = true and false;
- var_dump($x); </font>
復制代碼
部分同學或許會第一時間想到false,實際上:
這里依舊是強調(diào)運算符的優(yōu)先級,= 會比 and級別高點,因此等同下面的代碼
$x = true;
true and false
答案顯而易見。
Q7:經(jīng)過下面的運算 $x的值應(yīng)該是多少?
答案是 18 ,PHP是會根據(jù)上下文實現(xiàn) 類型的自動轉(zhuǎn)換上面的代碼我們可以這樣理解:
如果我們在與字符串進行數(shù)學運算,實際php會盡可能將字符串中的數(shù)組進行轉(zhuǎn)換,如果是數(shù)字開頭的話則轉(zhuǎn)換成改數(shù)字比如"15%"會變成15,如果不是數(shù)字開頭則會變成0; 上面的運算類似下面 :
Q8:運行下面的代碼, $text 的值是多少? strlen($text) 又會返回什么結(jié)果?
<?php
$text = 'John ';
$text[10] = 'Doe';
上面代碼執(zhí)行完畢后 $text = "John D" (John后面會有連續(xù)的5個空格) strlen($text) 會返回11
$text[10] = "Doe" 給某個字符串具體的某個位置具體字符時候,實際只會把D賦給 $text . 雖然 $text 才開始只有5個自負長度,但是php會默認填充空格。這和別的語言有些差別。
Q9:下面的輸出結(jié)果會是什么
$v = 1;
$m = 2;
$l = 3;
if( $l > $m > $v){
echo "yes";
}else{
echo "no";
}
實際的輸出是
"no",只要仔細分析就不難得出$l>$m 會轉(zhuǎn)換成1 ,則這個時候再和$m比較。
Q10:執(zhí)行下面代碼 $x 會變成什么值呢?
$x = NULL;
if ('0xFF' == 255) {
$x = (int)'0xFF';
}
實際的運行結(jié)果是
$x=0 而不是255.首先 'oxFF' == 255 我們好判斷,會進行轉(zhuǎn)換將16進制數(shù)字轉(zhuǎn)換成10進制數(shù)字,0xff -> 255.PHP使用 is_numeric_string 判斷字符串是否包含十六進制數(shù)字然后進行轉(zhuǎn)換。但是 $x = (int)'0xFF'; 是否也會變成255呢?顯然不是,將一個字符串進行強制類型轉(zhuǎn)換實際上用的是 convert_to_long ,它實際上是將字符串從左向右進行轉(zhuǎn)換,遇到非數(shù)字字符則停止。因此 0xFF 到x就停止了。所以 $x=0