当前位置:博客首页>>PHP >> 阅读正文

php实现a到z及其中的”奇怪现象”

作者: 郑晓 分类: PHP 发布于: 2014-04-08 16:58 浏览(7,722) 没有评论


版本一:

for($i=ord('a'); $i<ord('z'); $i++) {
    echo chr($i);
}


版本二(与第一版类似使用ascii):

for($i=0; $i<26; $i++) {
    echo chr($i+97);
}

版本三:

echo implode('', range('a', 'z'));

版本四(高智商坑爹版):

for($i='a'; $i!='aa'; $i++) {
    echo $i;
}

版本五:

for($i='a'; strlen($i)<2; $i++) {
    echo $i;
}

前两个循环很容易理解,a到z每个字母的ascii码值是递增不变的,所以这两个方法就是通过ascii值去做循环计算,用到了php内置的ord()和chr()函数。
第三个方法使用php内置的range()函数生成一个从a到z递增的数组,步长为1,之后用implode函数将数组合并成字符串。

后两个方法就是本篇标题中所要讲的”奇怪现象”。

从理论上来讲,咱们用for($i=’a’; $i<'z';$i++)的写法也很正确,合情合理。。。但现实是残酷的,试一下就会发现得到的并不是想要结果。前面a到z是出来了,后面又输出一长串字符。如果在for循环中每次输出一个换行再观察的话就会发现一个规则,a-z, 下一次输出了aa、ab、ac...az,然后是ba、bb、bc...bz.... 也就是php在给z加一后自动“进位”了。php一个奇特的26进制。当"当前位"的z加1后会向它前面的一位上增加1,然后当前位变为a。'z'++ => ‘aa’,’az’=>’ba’,’zz’=>’aaa’….

注意的两点:1.这种规律不能用于判断。如’z’<'aa'是false。php中字符串比较时只会由左至右依次比较。2.目前只发现在"前自加"或"前自减"时会出现此种规律,参与其它算术运算时php将纯字符串强转为0。

↓↓微信扫码请我吃份正宗的烤面筋,可带劲啦↓↓
       

本文采用知识共享署名-非商业性使用 3.0 中国大陆许可协议进行许可,转载时请注明出处及相应链接。

本文永久链接: https://www.zh30.com/php-shi-xian-a-dao-z-ji-qi-zhong-di-qi-guai-xian-xiang.html