亚洲精品中文字幕无乱码_久久亚洲精品无码AV大片_最新国产免费Av网址_国产精品3级片

php語言

10個值得深思的PHP面試問題

時間:2024-09-12 07:53:27 php語言 我要投稿
  • 相關推薦

10個值得深思的PHP面試問題

  本文所羅列的問題雖然看似簡單,但是每個背后都涵蓋了一個或幾個大家容易忽視的基礎知識點,希望能夠幫助到你的面試和平時工作。

10個值得深思的PHP面試問題

  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中= !相對== 更為嚴格需要要求數(shù)據(jù)類型一致。

  Q2:下面的輸出結果會是怎樣?

  $x = 5;

  echo $x;

  echo "
";

  echo $x+++$x++;

  echo "
";

  echo $x;

  echo "
";

  echo $x---$x--;

  echo "
";

  echo $x;

  實際運行結果是

  5

  11

  7

  1

  5

  關于 $x++ 和 $x–這個問題其實非常容易遇見,我們只需記住$x++使用最近的值,然后才自增。

  運算符的優(yōu)先級,++ 是明顯高于 +,因此先執(zhí)行++ 再執(zhí)行 + 。關于運算符的優(yōu)先級,有的時候我們真的可以通過括號來讓我們的程序更讓人直觀的了解,畢竟代碼不光是用于執(zhí)行的,有的時候或許團隊的可讀性也是提高效率的一種。

  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′轉換成一個數(shù)字而且默認去掉了前面的0也就是123==123

  var_dump(’0123′ === 123);// false很顯然上面的問題已經(jīng)說過了數(shù)字和字符串類型不一致。

  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需要傳入的參數(shù)都是數(shù)組,如果不是,則會返回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,實際上這里依舊是強調運算符的優(yōu)先級,= 會比 and級別高點,因此等同下面的代碼

  $x = true;

  true and false

  答案顯而易見。

  Q7:經(jīng)過下面的運算 $x的值應該是多少?

  $x = 3 + "15%" + "$25"

  答案是18,PHP是會根據(jù)上下文實現(xiàn)類型的自動轉換

  上面的代碼我們可以這樣理解,如果我們在與字符串進行數(shù)學運算,實際php會盡可能將字符串中的數(shù)組進行轉換,如果是數(shù)字開頭的話則轉換成改數(shù)字比如”15%”會變成15,如果不是數(shù)字開頭則會變成0; 上面的運算類似下面 :

  $x = 3 + 15 + 0

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

  $text = 'John ';

  $text[10] = 'Doe';

  上面代碼執(zhí)行完畢后 $text = “John D”(John后面會有連續(xù)的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:執(zhí)行下面代碼$x會變成什么值呢?

  $x = NULL;

  if ('0xFF' == 255) {

  $x = (int)'0xFF';

  }

  實際的運行結果是$x=0而不是255.

  首先’oxFF’ == 255我們好判斷,會進行轉換將16進制數(shù)字轉換成10進制數(shù)字,0xff -> 255.

  PHP使用is_numeric_string 判斷字符串是否包含十六進制數(shù)字然后進行轉換。

  但是$x = (int)’0xFF’;是否也會變成255呢?顯然不是,將一個字符串進行強制類型轉換實際上用的是convert_to_long,它實際上是將字符串從左向右進行轉換,遇到非數(shù)字字符則停止。因此0xFF到x就停止了。所以$x=0。

【10個值得深思的PHP面試問題】相關文章:

值得深思的PHP面試問題08-28

2017年php面試問題推薦10-11

php中死鎖問題剖析10-14

解析php中的foreach問題05-10

PHP高級工程師面試問題集合05-30

php面試題10-26

PHP面試試題精選07-25

2017經(jīng)典面試PHP試題05-24

完美解決PHP中文亂碼問題07-18

PHP浮點數(shù)計算問題10-07