Jadual Kandungan
uasort() Fungsi Pelaksanaan fungsi
Rumah pembangunan bahagian belakang masalah PHP Bagaimana untuk mengisih elemen dalam tatasusunan dalam php

Bagaimana untuk mengisih elemen dalam tatasusunan dalam php

Apr 18, 2023 pm 03:23 PM

Dalam PHP, untuk mengisih tatasusunan 2 dimensi, anda boleh menggunakan fungsi terbina dalam usort() dan uasort() untuk mencapainya. Kedua-dua fungsi boleh menyusun elemen dalam tatasusunan, tetapi pelaksanaannya sedikit berbeza. Fungsi

usort() akan mengisih tatasusunan asal dan mengembalikan nilai Boolean, manakala fungsi uasort() akan mengisih tatasusunan asal tetapi mengekalkan perkaitan antara pasangan nilai kunci, iaitu, tiada tatasusunan indeks baharu akan diwujudkan. Di bawah ini kami akan memperkenalkan cara menggunakan kedua-dua fungsi ini masing-masing.

usort()Fungsi

usort()Parameter pertama fungsi ialah tatasusunan yang perlu diisih, dan parameter kedua ialah fungsi perbandingan, yang dilaksanakan dengan menambah tatasusunan kepada tatasusunan yang perlu diisih kedudukan elemen dan mengembalikan nilai Boolean.

//示例数组$students
$students = array(
    array("name" => "张三", "age" => 22),
    array("name" => "李四", "age" => 20),
    array("name" => "王五", "age" => 25)
);

//比较函数cmp
function cmp($a, $b){
    if ($a["age"] == $b["age"]) {
        return 0;
    }
    return ($a["age"] < $b["age"]) ? -1 : 1;
}

//使用usort()排序
usort($students, "cmp");

//输出结果
var_dump($students);
Salin selepas log masuk

Dalam kod di atas, kami mula-mula mentakrifkan tatasusunan 2 dimensi $pelajar yang mengandungi tiga elemen, setiap elemen mengandungi dua pasangan nilai kunci "nama" dan "umur".

Seterusnya, kami mentakrifkan fungsi perbandingan cmp, yang menentukan susunan relatif antara elemen dengan membandingkan nilai dua elemen pada pasangan nilai kunci "umur". Jika "umur" dua elemen adalah sama, 0 dikembalikan jika "umur" $a kurang daripada "umur" $b, maka -1 dikembalikan, menunjukkan bahawa $a berada di hadapan $ b; jika tidak, 1 dikembalikan, menunjukkan bahawa $a Selepas $b.

Akhir sekali, kami menggunakan fungsi usort() untuk mengisih tatasusunan $pelajar mengikut peraturan yang ditakrifkan oleh fungsi cmp. Daripada output, anda boleh melihat bahawa elemen dalam tatasusunan telah diisih dari kecil ke besar mengikut pasangan nilai kunci "umur".

uasort() Fungsi Pelaksanaan fungsi

uasort() adalah serupa dengan usort(), tetapi perbezaannya ialah perkaitan antara pasangan nilai kunci dikekalkan dan tiada tatasusunan indeks baharu dicipta. Oleh itu, ia memerlukan fungsi perbandingan yang lebih kompleks yang bukan sahaja membandingkan saiz elemen tetapi juga mengekalkan perkaitan pasangan nilai kunci.

//示例数组$students
$students = array(
    "stu1" => array("name" => "张三", "age" => 22),
    "stu2" => array("name" => "李四", "age" => 20),
    "stu3" => array("name" => "王五", "age" => 25)
);

//比较函数cmp
function cmp($a, $b){
    if ($a["age"] == $b["age"]) {
        return 0;
    }
    return ($a["age"] < $b["age"]) ? -1 : 1;
}

//使用usort()排序
uasort($students, "cmp");

//输出结果
var_dump($students);
Salin selepas log masuk

Dalam kod di atas, kami mula-mula mentakrifkan tatasusunan bersekutu 2 dimensi $pelajar yang mengandungi tiga elemen, setiap elemen mengandungi dua pasangan nilai kunci "nama" dan "umur". Perbezaannya ialah di sini kita menggunakan rentetan "stu1", "stu2" dan "stu3" sebagai nilai utama tatasusunan dan bukannya indeks berangka sebelumnya.

mentakrifkan fungsi perbandingan cmp dengan cara yang sama seperti usort(). Perbezaannya ialah apabila kita memanggil fungsi uasort(), kita lulus tatasusunan $pelajar dan fungsi perbandingan cmp sebagai parameter. Fungsi ini mengisih tatasusunan mengikut peraturan cmp dan hasil yang diisih mengekalkan perhubungan nilai kunci bersama asal.

Akhir sekali, kami mengeluarkan hasil pengisihan melalui fungsi var_dump(). Seperti yang anda lihat, hasil keluaran masih merupakan tatasusunan bersekutu, tetapi elemen telah diisih dari kecil ke besar mengikut pasangan nilai kunci "umur".

Selain usort() dan uasort(), PHP juga menyediakan satu siri fungsi pengisihan tatasusunan lain, seperti asort(), arsort(), ksort(), krsort(), dsb., pembangun boleh Pilih fungsi yang sesuai mengikut keperluan sebenar.

Atas ialah kandungan terperinci Bagaimana untuk mengisih elemen dalam tatasusunan dalam php. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
2 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
Repo: Cara menghidupkan semula rakan sepasukan
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Cara mendapatkan biji gergasi
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Apakah amalan terbaik untuk deduplikasi tatasusunan php Apakah amalan terbaik untuk deduplikasi tatasusunan php Mar 03, 2025 pm 04:41 PM

Artikel ini meneroka deduplikasi array PHP yang cekap. Ia membandingkan fungsi terbina dalam seperti array_unique () dengan pendekatan hashmap tersuai, menonjolkan prestasi perdagangan berdasarkan saiz array dan jenis data. Kaedah optimum bergantung pada profili

Bolehkah PHP Array Deduplication memanfaatkan keunikan nama utama? Bolehkah PHP Array Deduplication memanfaatkan keunikan nama utama? Mar 03, 2025 pm 04:51 PM

Artikel ini meneroka deduplikasi PHP Array menggunakan keunikan utama. Walaupun bukan kaedah penyingkiran pendua langsung, memanfaatkan keunikan utama membolehkan membuat array baru dengan nilai yang unik dengan nilai pemetaan ke kekunci, menimpa duplikat. AP ini

Adakah Deduplication Array PHP perlu dipertimbangkan untuk kerugian prestasi? Adakah Deduplication Array PHP perlu dipertimbangkan untuk kerugian prestasi? Mar 03, 2025 pm 04:47 PM

Artikel ini menganalisis PHP Array Deduplication, menonjolkan kemunculan prestasi pendekatan naif (O (N²)). Ia meneroka alternatif yang cekap menggunakan array_unique () dengan fungsi tersuai, splobjectstorage, dan pelaksanaan hashset, mencapai

Bagaimana untuk melaksanakan beratur mesej (RabbitMQ, Redis) dalam PHP? Bagaimana untuk melaksanakan beratur mesej (RabbitMQ, Redis) dalam PHP? Mar 10, 2025 pm 06:15 PM

Butiran artikel ini melaksanakan beratur mesej dalam PHP menggunakan RabbitMQ dan Redis. Ia membandingkan seni bina mereka (AMQP vs dalam memori), ciri-ciri, dan mekanisme kebolehpercayaan (pengesahan, urus niaga, kegigihan). Amalan terbaik untuk reka bentuk, kesilapan

Apakah piawaian pengekodan PHP terkini dan amalan terbaik? Apakah piawaian pengekodan PHP terkini dan amalan terbaik? Mar 10, 2025 pm 06:16 PM

Artikel ini mengkaji piawaian pengekodan PHP semasa dan amalan terbaik, memberi tumpuan kepada cadangan PSR (PSR-1, PSR-2, PSR-4, PSR-12). Ia menekankan peningkatan kebolehbacaan dan kebolehkerjaan kod melalui gaya yang konsisten, penamaan bermakna, dan EFF

Apakah teknik pengoptimuman untuk deduplikasi tatasusunan php Apakah teknik pengoptimuman untuk deduplikasi tatasusunan php Mar 03, 2025 pm 04:50 PM

Artikel ini meneroka mengoptimumkan deduplikasi array PHP untuk dataset yang besar. Ia mengkaji teknik-teknik seperti array_unique (), array_flip (), splobjectstorage, dan pra-sorting, membandingkan kecekapan mereka. Untuk dataset besar -besaran, ia mencadangkan pemotongan, pangkalan data

Bagaimana saya bekerja dengan sambungan php dan pecl? Bagaimana saya bekerja dengan sambungan php dan pecl? Mar 10, 2025 pm 06:12 PM

Butiran artikel ini memasang dan menyelesaikan masalah PHP, memberi tumpuan kepada PECL. Ia meliputi langkah pemasangan (mencari, memuat turun/menyusun, membolehkan, memulakan semula pelayan), teknik penyelesaian masalah (memeriksa log, mengesahkan pemasangan,

Bagaimana menggunakan refleksi untuk menganalisis dan memanipulasi kod PHP? Bagaimana menggunakan refleksi untuk menganalisis dan memanipulasi kod PHP? Mar 10, 2025 pm 06:12 PM

Artikel ini menerangkan API Refleksi PHP, membolehkan pemeriksaan runtime dan manipulasi kelas, kaedah, dan sifat. IT memperincikan kes penggunaan biasa (penjanaan dokumentasi, ORM, suntikan pergantungan) dan memberi amaran terhadap prestasi overhea

See all articles