教育行業(yè)A股IPO第一股(股票代碼 003032)

全國(guó)咨詢(xún)/投訴熱線(xiàn):400-618-4000

全棧開(kāi)發(fā)培訓(xùn)之值得深思的面試問(wèn)題

更新時(shí)間:2018年02月04日11時(shí)24分 來(lái)源: 瀏覽次數(shù):

10個(gè)問(wèn)題,看似簡(jiǎn)單,但是每個(gè)背后都涵蓋了一個(gè)或幾個(gè)大家容易忽視的基礎(chǔ)知識(shí)點(diǎn),希望能夠幫助到你的面試和平時(shí)工作。

Q1第一個(gè)問(wèn)題關(guān)于 弱類(lèi)型

  1. <?php
  2. $str1 = 'yabadabadoo';
  3. $str2 = 'yaba';
  4. if (strpos($str1,$str2)) {  
  5.     echo "\"" . $str1 . "\" contains \"" . $str2 . "\"";
  6. } else {
  7.     echo "\"" . $str1 . "\" does not contain \"" . $str2 . "\"";
  8. }
復(fù)制代碼



正確運(yùn)行的輸出結(jié)果:
  1. "yabadabadoo" does not contain "yaba"
復(fù)制代碼
strpos 是返回字符串 str2 在 str1 的位置,沒(méi)有找到則返回 false ,然而實(shí)際上這次返回了 0 而在if語(yǔ)句中0也被當(dāng)作false,所以我們需要對(duì)false做類(lèi)型判斷,正確的代碼如下:

  1. <?php
  2.       $str1 = 'yabadabadoo';
  3.       $str2 = 'yaba';
  4.       if (strpos($str1,$str2) !== false) {  
  5.           echo "\"" . $str1 . "\" contains \"" . $str2 . "\"";
  6.       } else {
  7.             echo "\"" . $str1 . "\" does not contain \"" . $str2 . "\"";
  8.       }
復(fù)制代碼

需要注意的是我們使用了 !== ,在php 和 JS中 != 相對(duì)== 更為嚴(yán)格需要要求數(shù)據(jù)類(lèi)型一致.




Q2 :下面的輸出結(jié)果會(huì)是怎樣?

  1. <?php
  2.         $x = 5;
  3.         echo $x;  
  4.        echo "<br />";  
  5.        echo $x+++$x++;  
  6.        echo "<br />";  
  7.        echo $x;  
  8.        echo "<br />";  
  9.        echo $x---$x--;  
  10.        echo "<br />";  
  11.         echo $x;  
復(fù)制代碼

實(shí)際運(yùn)行結(jié)果是:
關(guān)于 $x++ 和 $x-- 這個(gè)問(wèn)題其實(shí)非常容易遇見(jiàn),我們只需記住 $x++ 使用最近的值,然后才自增。運(yùn)算符的優(yōu)先級(jí), ++ 是明顯高于 + ,因此先執(zhí)行++ 再執(zhí)行 + 。關(guān)于運(yùn)算符的優(yōu)先級(jí),有的時(shí)候我們真的可以通過(guò)括號(hào)來(lái)讓我們的程序更讓人直觀(guān)的了解,畢竟代碼不光是用于執(zhí)行的,有的時(shí)候或許團(tuán)隊(duì)的可讀性也是提高效率的一種。



Q3:關(guān)于變量的引用;

  1. <?php
  2.       $a = '1';
  3.       $b = &$a;
  4.       $b = "2$b";
復(fù)制代碼

請(qǐng)問(wèn) $a 和 $b 的值各位多少?
部分第一時(shí)間會(huì)想到 $a='1' $b='21' ,仔細(xì)一看 $b=&$a ,這里 $b 是變量 $a 的引用,而不是直接賦值。




Q4:下面是true還是false
  1. <font size="2"><?php
  2. var_dump(0123 == 123);  
  3. var_dump('0123' == 123);  
  4. var_dump('0123' === 123);</font>
復(fù)制代碼


var_dump(0123 == 123);// false ,PHP會(huì)默認(rèn)把0123當(dāng)作8進(jìn)制來(lái)處理,實(shí)際轉(zhuǎn)化為10進(jìn)制就是83,顯然這不是相等的。
var_dump('0123' == 123);// true 這里php會(huì)非常有趣的將'0123'轉(zhuǎn)換成一個(gè)數(shù)字而且默認(rèn)去掉了前面的0也就是 123==123
var_dump('0123' === 123);// false 很顯然上面的問(wèn)題已經(jīng)說(shuō)過(guò)了數(shù)字和字符串類(lèi)型不一致。




Q5:下面的代碼有什么問(wèn)題嗎?輸出會(huì)是什么,怎樣修復(fù)它
  1. <font size="2"><?php
  2.        $referenceTable = array();
  3.        $referenceTable['val1'] = array(1, 2);
  4.        $referenceTable['val2'] = 3;
  5.        $referenceTable['val3'] = array(4, 5);
  6.        $testArray = array();
  7.         $testArray = array_merge($testArray, $referenceTable['val1']);
  8.        var_dump($testArray);  
  9.        $testArray = array_merge($testArray, $referenceTable['val2']);
  10.        var_dump($testArray);  
  11.       $testArray = array_merge($testArray, $referenceTable['val3']);
  12.       var_dump($testArray);  </font>
復(fù)制代碼

實(shí)際輸出如下:

array(2) { [0]=> int(1) [1]=> int(2) }  
NULL  
NULL  

運(yùn)行的時(shí)候你或許還能看到下面的警告

Warning: array_merge(): Argument #2 is not an array  
Warning: array_merge(): Argument #1 is not an array  

array_merge 需要傳入的參數(shù)都是數(shù)組,如果不是,則會(huì)返回null。 你可以這樣修改

  1. <?php
  2. $testArray = array_merge($testArray, (array)$referenceTable['val1']);
  3. var_dump($testArray);  
  4. $testArray = array_merge($testArray, (array)$referenceTable['val2']);
  5. var_dump($testArray);  
  6. $testArray = array_merge($testArray, (array)$referenceTable['val3']);
  7. var_dump($testArray);  
復(fù)制代碼


Q6: $x應(yīng)該是輸出什么?
  1. <?php
  2.         $x = true and false;
  3.         var_dump($x);  </font>
復(fù)制代碼

部分同學(xué)或許會(huì)第一時(shí)間想到false,實(shí)際上:
這里依舊是強(qiáng)調(diào)運(yùn)算符的優(yōu)先級(jí),= 會(huì)比 and級(jí)別高點(diǎn),因此等同下面的代碼

   $x = true;
   true and false  

答案顯而易見(jiàn)。



Q7:經(jīng)過(guò)下面的運(yùn)算 $x的值應(yīng)該是多少?
  1. $x = 3 + "15%" + "$25"
復(fù)制代碼
答案是 18 ,PHP是會(huì)根據(jù)上下文實(shí)現(xiàn) 類(lèi)型的自動(dòng)轉(zhuǎn)換上面的代碼我們可以這樣理解:
如果我們?cè)谂c字符串進(jìn)行數(shù)學(xué)運(yùn)算,實(shí)際php會(huì)盡可能將字符串中的數(shù)組進(jìn)行轉(zhuǎn)換,如果是數(shù)字開(kāi)頭的話(huà)則轉(zhuǎn)換成改數(shù)字比如"15%"會(huì)變成15,如果不是數(shù)字開(kāi)頭則會(huì)變成0; 上面的運(yùn)算類(lèi)似下面 :
  1. $x = 3 + 15 + 0
復(fù)制代碼



Q8:運(yùn)行下面的代碼, $text 的值是多少? strlen($text) 又會(huì)返回什么結(jié)果?

<?php
    $text = 'John ';
    $text[10] = 'Doe';


上面代碼執(zhí)行完畢后 $text = "John D" (John后面會(huì)有連續(xù)的5個(gè)空格) strlen($text) 會(huì)返回11
$text[10] = "Doe" 給某個(gè)字符串具體的某個(gè)位置具體字符時(shí)候,實(shí)際只會(huì)把D賦給 $text . 雖然 $text 才開(kāi)始只有5個(gè)自負(fù)長(zhǎng)度,但是php會(huì)默認(rèn)填充空格。這和別的語(yǔ)言有些差別。



Q9:下面的輸出結(jié)果會(huì)是什么

    $v = 1;
     $m = 2;
     $l = 3;
     if( $l > $m > $v){  
          echo "yes";
     }else{
        echo "no";
     }

實(shí)際的輸出是
"no",只要仔細(xì)分析就不難得出$l>$m 會(huì)轉(zhuǎn)換成1 ,則這個(gè)時(shí)候再和$m比較。



Q10:執(zhí)行下面代碼 $x 會(huì)變成什么值呢?


     $x = NULL;
     if ('0xFF' == 255) {  
         $x = (int)'0xFF';
     }


實(shí)際的運(yùn)行結(jié)果是
$x=0 而不是255.首先 'oxFF' == 255 我們好判斷,會(huì)進(jìn)行轉(zhuǎn)換將16進(jìn)制數(shù)字轉(zhuǎn)換成10進(jìn)制數(shù)字,0xff -> 255.PHP使用 is_numeric_string 判斷字符串是否包含十六進(jìn)制數(shù)字然后進(jìn)行轉(zhuǎn)換。但是 $x = (int)'0xFF'; 是否也會(huì)變成255呢?顯然不是,將一個(gè)字符串進(jìn)行強(qiáng)制類(lèi)型轉(zhuǎn)換實(shí)際上用的是 convert_to_long ,它實(shí)際上是將字符串從左向右進(jìn)行轉(zhuǎn)換,遇到非數(shù)字字符則停止。因此 0xFF 到x就停止了。所以 $x=0


本文版權(quán)歸傳智播客H5+全棧學(xué)院所有,歡迎轉(zhuǎn)載,轉(zhuǎn)載請(qǐng)注明作者出處。謝謝!

作者:傳智播客H5+全棧學(xué)院

首發(fā):http://fskzgqt.cn/subject/stackzly/index.shtml
0 分享到:
和我們?cè)诰€(xiàn)交談!