一、問題一關於弱類型php
$str1 = 'yabadabadoo';數組
$str2 = 'yaba';ide
if (strpos($str1,$str2)) { 字符串
echo "\\"" . $str1 . "\\" contains \\"" . $str2 . "\\"";數學
} else {string
echo "\\"" . $str1 . "\\" does not contain \\"" . $str2 . "\\"";it
}class
正確運行的輸出結果:test
"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中= !相對== 更爲嚴格須要要求數據類型的一致。
二、下面的輸出結果會是怎樣?
$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++使用最近的值,而後才自增。
運算符的優先級,++ 是明顯高於 +,所以先執行++ 再執行 + 。關於運算符的優先級,有的時候咱們真的能夠經過括號來讓咱們的程序更加讓人直觀的瞭解,畢竟代碼它不光是用於執行的,有的時候或許團隊的可讀性也是提升效率的一種。
三、關於變量的引用;
$a = '1';
$b = &$a;
$b = "2$b";
問 $a 和 $b的值各位多少
部分第一時間會想到 $a='1' $b='21',仔細一看 $b=&$a,這裏$b是變量$a的引用而不是直接 賦值。
四、下面是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很顯然上面的問題已經說過了數字和字符串類型不一致。
五、下面的代碼有什麼問題嗎?輸出會是什麼,怎樣修復它
$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);
六、$x應該是輸出什麼?
$x = true and false;
var_dump($x);
部分同窗或許會第一時間想到false,實際上這裏依舊是強調運算符的優先級,= 會比 and級別高點,所以等同下面的代碼
$x = true;
true and false
答案顯而易見。
七、通過下面的運算 $x的值應該是多少?
$x = 3 + "15%" + "$25"
答案是18,PHP是會根據上下文實現類型的自動轉換
上面的代碼咱們能夠這樣理解,若是咱們在與字符串進行數學運算,實際php會盡量將字符串中的數組進行轉換,若是是數字開頭的話則轉換成改數字好比"15%"會變成15,若是不是數字開頭則會變成0; 上面的運算相似下面 :
$x = 3 + 15 + 0
八、運行下面的代碼,$text 的值是多少?strlen($text)又會返回什麼結果?
$text = 'John ';
$text[10] = 'Doe';
上面代碼執行完畢後 $text = "John D"(John後面會有連續的5個空格) strlen($text)會返回11
$text[10] = "Doe"給某個字符串具體的某個位置具體字符時候,實際只會把D賦給$text. 雖然$text纔開始只有5個自負長度,可是php會默認填充空格。這和別的語言有些差異。
九、下面的輸出結果會是什麼
$v = 1;
$m = 2;
$l = 3;
if( $l > $m > $v){
echo "yes";
}else{
echo "no";
}
實際的輸出是"no",只要仔細分析就不可貴出
$l>$m 會轉換成1 ,則這個時候再和$m比較。
十、執行下面代碼$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