PHP的数字排序

2017-01-13 10:52:51来源:作者:cakin24人点击

一 实例
<?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,否则如果两个字符串都是”纯数字“形式的,就会按照它们所代表的数字大小进行排序。而且需要注意的是,如果两个值的类型不同,那么这样的比较是毫无意义的,也可能会产生意想不到的结果。

最新文章

123

最新摄影

微信扫一扫

第七城市微信公众平台