前遞增++++$a$a自增1,然後回傳$a
後遞增++$a++先回傳$a,然後$a自增1
前遞減----$a$a自減1,再回傳$a
後遞減--$a--先回傳$a ,然後$a自減1
第一個注意事:遞增/遞減運算子不影響布林值。遞減NULL值也沒有效果,但是遞增NULL的結果是1。
換句話說:遞增/遞減運算中,不會把運算元轉換成整數後再運算。如果運算數是布林值,則直接傳回結果。
遞增/遞減布林值:
$a = TRUE; var_dump(++$a); // bool(true) $a = TRUE; var_dump(--$a); // bool(true) $b = FALSE; var_dump(++$b); // bool(false) $b = FALSE; var_dump(--$b); // bool(false)
遞增/遞減NULL:
$a = NULL; var_dump(++$a); // int(1) $a = NULL; var_dump(--$a); // NULL
在處理字元變數的算數運算時,PHP 沿襲了Perl 的習慣,而非C的。
例如,在Perl 中
$a = 'Z'; $a++;
將把$a變成'AA',而在C 中,
a = 'Z'; a++;
將把a變成'['(' Z'的ASCII 值是90,'['的ASCII 值是91)。
注意字元變數只能遞增,不能遞減,並且只支援純字母(a-z 和 A-Z)。
例如:
$a="9D9"; var_dump(++$a); // string(3) "9E0"
但是,這裡又有一個陷阱了:
$a="9E0"; echo ++$a; // 10
安裝上面的規則,應該輸出9E1,但這裡卻輸出了10。為什麼?
如果我們這麼寫,大部就知道是為什麼了。
$a = "9E0"; var_dump(++$a); // float(10)
$a的型別是浮點型,也就是說,9E0是浮點數的科學記數法,即9 * 10^0 = 9,對9自增,結果當然是10了。
參考:字串轉換成數值
現在問題又來了:
$l = "Z99"; $l++;
這個結果是多少呢?結果依照 perl 語言的規則,是"AA00"。
還有一個注意事項:
遞增/遞減其他字元變數則無效,原始字串沒有變化。
這個就不解釋了。
最後一個注意事項:
$a = '012'; $a++; var_dump($a);
這個結果是'013'? 13?11?
這段的結果是int(13),字串'012'並沒有被當作八進位。
$a = 012; // 八进制,十进制为 10 $b = "012"; // 转换为整数为十进制 12
如果是0x開頭的呢?
$a = '0x1A'; $a++; var_dump($a); // int(27)
0開頭的不被認為是八進制,但是0x開頭的卻被認為是十六進制。
在 PHP 官方文档中 Integer 整型 还有另一个八进制陷阱:
var_dump(01090); // 八進位 010 = 十進位 8
手冊中對此的解釋為:
Warning 如果向八进制数传递了一个非法数字(即 8 或 9),则后面其余数字会被忽略。
以上是php遞增遞減運算子理解及注意事項的詳細內容。更多資訊請關注PHP中文網其他相關文章!