来源:自学PHP网 时间:2014-11-27 22:16 作者: 阅读:次
[导读] 版本一:for($i=ord( 39;a 39;);$iord( 39;z 39;);$i++){echochr($i);}版本二(与第一版类似使用ascii):for($i=0;$i26;$i++){echochr($i+97);}版本三:echo implode( 39; 39;, range( 39;a...
php实现a到z及其中的”奇怪现象”版本一:
版本二(与第一版类似使用ascii):
版本三:echo implode('', range('a', 'z')); 版本四(高智商坑爹版):
版本五:
前两个循环很容易理解,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. |
自学PHP网专注网站建设学习,PHP程序学习,平面设计学习,以及操作系统学习
京ICP备14009008号-1@版权所有www.zixuephp.com
网站声明:本站所有视频,教程都由网友上传,站长收集和分享给大家学习使用,如由牵扯版权问题请联系站长邮箱904561283@qq.com