PHP的数字排序

来源:互联网 发布:heu kms 知彼而知己 编辑:程序博客网 时间:2024/06/06 05:52
一 实例
<?php $array=array(1,4,8,25,0,42,88,66); $array1=sort($array,SORT_STRING);   //用sort()函数对$array数组进行升序排序,并返回新数组$array1 for($i=0;$i<count($array);$i++){//应用for循环语句输出数组元素   echo $array[$i]."&nbsp;&nbsp;"; }?>
 
二 运行结果
0  1  25  4  42  66  8  88 
当将SORT_STRING修改为SORT_REGULAR ,排序顺序如下:
0  1  4  8  25  42  66  88 
三 总结
SORT_STRING 排序方式的底层实现是 C 语言的 memcmp,也就是说,它对两个字符串从前往后,按照逐个字节比较,一旦字节有差异,就终止并比较出大小。
SORT_REGULAR 会智能判断需排序对象的类型,如果两个字符串都是“纯数字”形式的字符串,会以比较整个字符串所代表的十进制整数、浮点数大小的形式进行排序。如果两个字符串不是“纯数字“形式的,才会和 SORT_STRING 一样。
因此,如果需要以字符串 strcmp 方式逐个字节从前往后比较来进行排序,在调用 php 的 sort 类函数的时候请务必使用 SORT_STRING 这个 flag,否则如果两个字符串都是”纯数字“形式的,就会按照它们所代表的数字大小进行排序。
而且需要注意的是,如果两个值的类型不同,那么这样的比较是毫无意义的,也可能会产生意想不到的结果。
0 0
原创粉丝点击