有同學(xué)問了一個(gè)問題:
復(fù)制代碼代碼如下:
<?php
for($i = 'A'; $i <= 'Z'; $i++) {
echo $i;
}
輸出是啥?
輸出是:
ABCDEFGHIJKLMNOPQRSTUVWXYZAAABACADAEAFAGAHAIAJAKALAMANAOAPAQARAS…….
為啥?
其實(shí)很簡單, PHP的手冊中也有說明, 只不過恐怕很多人不會(huì)一章一節(jié)的把手冊仔細(xì)閱讀一遍:
PHP follows Perl's convention when dealing with arithmetic operations on character variables and not C's. For example, in Perl ‘Z'+1 turns into ‘AA', while in C ‘Z'+1 turns into ‘[‘ ( ord(‘Z') == 90, ord(‘[‘) == 91 ). Note that character variables can be incremented but not decremented and even so only plain ASCII characters (a-z and A-Z) are supported.
在處理字符變量的算數(shù)運(yùn)算時(shí),PHP 沿襲了 Perl 的習(xí)慣,而非 C 的。例如,在 Perl 中 ‘Z'+1 將得到 ‘AA',而在 C 中,'Z'+1 將得到 ‘[‘(ord(‘Z') == 90,ord(‘[‘) == 91)。注意字符變量只能遞增,不能遞減,并且只支持純字母(a-z 和 A-Z)。
也就是說, 如果:
復(fù)制代碼代碼如下:
$name = "laruence";
++$name; //將會(huì)是"laruencf"
而:
復(fù)制代碼代碼如下:
$name = "laruence";
--$name; //沒有影響, 還是"laruence"
所以, 這個(gè)問題的原因就是當(dāng)$i = Z的時(shí)候, ++$i成了AA, 而字符串比較的話,
AA,BB,XX一直到Y(jié)Z都是小于等于Z的… so..