溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

PHP面試題中有哪10個(gè)題值得深思

發(fā)布時(shí)間:2021-09-06 16:09:24 來源:億速云 閱讀:131 作者:Yi 欄目:開發(fā)技術(shù)

這期內(nèi)容當(dāng)中小編將會(huì)給大家?guī)碛嘘P(guān)PHP面試題中有哪10個(gè)題值得深思,文章內(nèi)容豐富且以專業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

Q1

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

$str1 = 'yabadabadoo';
$str2 = 'yaba';
if (strpos($str1,$str2)) { 
  echo "/"" . $str1 . "/" contains /"" . $str2 . "/"";
} else {
  echo "/"" . $str1 . "/" does not contain /"" . $str2 . "/"";
}

正確運(yùn)行的輸出結(jié)果:

"yabadabadoo" does not contain "yaba"

strpos是返回字符串str2在str1的位置,沒有找到則返回false然而實(shí)際上這次返回了0而在if語句中0也被當(dāng)作false,所以我們需要對(duì)false做類型判斷,正確的代碼如下:

$str1 = 'yabadabadoo';
$str2 = 'yaba';
if (strpos($str1,$str2) !== false) { 
  echo "/"" . $str1 . "/" contains /"" . $str2 . "/"";
} else {
  echo "/"" . $str1 . "/" does not contain /"" . $str2 . "/"";
}

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

Q2

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

$x = 5;
echo $x; 
echo "<br />"; 
echo $x+++$x++; 
echo "<br />"; 
echo $x; 
echo "<br />"; 
echo $x---$x--; 
echo "<br />"; 
echo $x;

實(shí)際運(yùn)行結(jié)果是

5
11
7
1
5
關(guān)于 $x++ 和 $x–這個(gè)問題其實(shí)非常容易遇見,我們只需記住$x++使用最近的值,然后才自增。

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

Q3

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

$a = '1';
$b = &$a;
$b = "2$b";

請(qǐng)問 $a 和 $b的值各位多少

部分第一時(shí)間會(huì)想到 $a='1′ $b='21′,仔細(xì)一看 $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會(huì)默認(rèn)把0123當(dāng)作8進(jìn)制來處理,實(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很顯然上面的問題已經(jīng)說過了數(shù)字和字符串類型不一致。

Q5

下面的代碼有什么問題嗎?輸出會(huì)是什么,怎樣修復(fù)它

$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);

實(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。 你可以這樣修改

$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)該是輸出什么?

$x = true and false;
var_dump($x);

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

$x = true;
true and false

答案顯而易見。

Q7

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

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

答案是18,PHP是會(huì)根據(jù)上下文實(shí)現(xiàn)類型的自動(dòng)轉(zhuǎn)換

上面的代碼我們可以這樣理解,如果我們?cè)谂c字符串進(jìn)行數(shù)學(xué)運(yùn)算,實(shí)際php會(huì)盡可能將字符串中的數(shù)組進(jìn)行轉(zhuǎn)換,如果是數(shù)字開頭的話則轉(zhuǎn)換成改數(shù)字比如”15%”會(huì)變成15,如果不是數(shù)字開頭則會(huì)變成0; 上面的運(yùn)算類似下面 :

$x = 3 + 15 + 0

Q8

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

$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才開始只有5個(gè)自負(fù)長(zhǎng)度,但是php會(huì)默認(rèn)填充空格。這和別的語言有些差別。

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)制類型轉(zhuǎn)換實(shí)際上用的是convert_to_long,它實(shí)際上是將字符串從左向右進(jìn)行轉(zhuǎn)換,遇到非數(shù)字字符則停止。因此0xFF到x就停止了。所以$x=0

上述就是小編為大家分享的PHP面試題中有哪10個(gè)題值得深思了,如果剛好有類似的疑惑,不妨參照上述分析進(jìn)行理解。如果想知道更多相關(guān)知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

php
AI