usort、uksort與sort函數(shù)怎么在php中使用?相信很多沒有經(jīng)驗的人對此束手無策,為此本文總結(jié)了問題出現(xiàn)的原因和解決方法,通過這篇文章希望你能解決這個問題。
目前成都創(chuàng)新互聯(lián)公司已為上1000家的企業(yè)提供了網(wǎng)站建設、域名、虛擬空間、綿陽服務器托管、企業(yè)網(wǎng)站設計、潯陽網(wǎng)站維護等服務,公司將堅持客戶導向、應用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶和合作伙伴齊心協(xié)力一起成長,共同發(fā)展。對數(shù)組排序:usort() 函數(shù)使用用戶自定義的函數(shù)對數(shù)組排序,實例代碼如下:
復制代碼 代碼如下:
function cmp($a, $b) //用戶自定義回調(diào)函數(shù)
{
if($a==$b) //如果兩個參數(shù)相等
{
return 0; //返回0
}
return($a>$b)?-1:1; //如果第1個參數(shù)大于第2個返回1,否則-1
}
$a=array(3,2,5,6,1); //定義一個數(shù)組
usort ($a,"cmp"); //使用自定義函數(shù)對數(shù)組排序
foreach($a as $key=>$value) //循環(huán)輸出排序后的鍵值對
{
echo "$key:$valuen";
}
注釋:如果兩個元素比較結(jié)果相同,則它們在排序后的數(shù)組中的順序未經(jīng)定義,到 php 4.0.6 之前,用戶自定義函數(shù)將保留這些元素的原有順序,但是由于在 4.1.0 中引進了新的排序算法,結(jié)果將不是這樣了,因為對此沒有一個有效的解決方案.
對數(shù)組鍵名排序 uksort(array,sorttype),實例代碼如下:
復制代碼 代碼如下:
function cmp($a, $b) //用戶自定義回調(diào)函數(shù)
{
if($a==$b) //如果兩個參數(shù)相等
{
return 0; //返回0
}
return($a>$b)?-1:1; //如果第1個參數(shù)大于第2個返回1,否則-1
}
$a=array(4=>"four",3 =>"three",20 =>"twenty",10=>"ten"); //定義一個數(shù)組
uksort ($a,"cmp"); //使用自定義函數(shù)對數(shù)組鍵名排序
foreach($a as $key=>$value) //循環(huán)輸出排序后的鍵值對
{
echo "$key:$valuen";
}
uksort() 函數(shù)使用用戶自定義的比較函數(shù)按照鍵名對數(shù)組排序,并保持索引關(guān)系,如果成功則返回 true,否則返回 false.
如果要排序的數(shù)組需要用一種不尋常的標準進行排序,那么應該使用此函數(shù),自定義函數(shù)應接受兩個參數(shù),該參數(shù)將被數(shù)組中的一對鍵名填充,比較函數(shù)在第一個參數(shù)小于,等于,或大于第二個參數(shù)時必須分別返回一個小于零,等于零,或大于零的整數(shù).
sort() 函數(shù)按升序?qū)o定數(shù)組的值排序.
注釋:本函數(shù)為數(shù)組中的單元賦予新的鍵名,原有的鍵名將被刪除,如果成功則返回 true,否則返回 false,實例代碼如下:
復制代碼 代碼如下:
$fruits=array("lemon","orange","banana","apple"); //定義一個數(shù)組
sort($fruits); //對數(shù)組進行排序
foreach($fruits as $key=>$val) //循環(huán)輸出數(shù)組排序后的鍵值對
{
echo "$key=$valn"; //輸出鍵值對
}
看完上述內(nèi)容,你們掌握usort、uksort與sort函數(shù)怎么在php中使用的方法了嗎?如果還想學到更多技能或想了解更多相關(guān)內(nèi)容,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝各位的閱讀!
當前名稱:usort、uksort與sort函數(shù)怎么在php中使用-創(chuàng)新互聯(lián)
文章分享:http://www.rwnh.cn/article16/ddcogg.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供云服務器、品牌網(wǎng)站建設、移動網(wǎng)站建設、網(wǎng)站設計公司、服務器托管、網(wǎng)站設計
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)