PHP menentukan sama ada ia wujud dalam tatasusunan
Dalam pembangunan PHP, kita sering menghadapi situasi di mana kita perlu menentukan sama ada elemen wujud dalam tatasusunan Dalam kes ini, kita biasanya menggunakan fungsi in_array() atau fungsi array_search(). Di bawah ini kami akan memperkenalkan penggunaan dan perbezaan kedua-dua fungsi ini secara terperinci.
1. Fungsi in_array()
Fungsi in_array() ialah fungsi yang biasa digunakan dalam PHP untuk menentukan sama ada elemen wujud dalam tatasusunan Ia digunakan seperti berikut:
bool in_array(mixed $needle, array $haystack [, bool $strict]);
Antaranya, $needle mewakili elemen yang akan ditemui, $hystack mewakili array yang akan ditemui, $strict mewakili sama ada untuk membandingkan secara kongruen, Nilai pulangannya ialah nilai Boolean.
Kod sampel adalah seperti berikut:
$fruits = array("apple", "banana", "orange", "tomato"); if (in_array("apple", $fruits)) { echo "有苹果!"; } else { echo "没有苹果。"; }
Hasil output ialah "Ada epal!".
2. Fungsi array_search()
Fungsi array_search() mempunyai fungsi yang serupa dengan fungsi in_array() dan juga boleh digunakan untuk mencari sama ada unsur wujud dalam tatasusunan. Tidak seperti fungsi in_array(), fungsi array_search() mengembalikan subskrip elemen atau false.
Fungsi array_search() digunakan seperti berikut:
mixed array_search(mixed $needle, array $haystack [, bool $strict]);
Antaranya, $ needle bermaksud Elemen yang hendak dicari, $haystack mewakili tatasusunan yang hendak dicari, dan $strict mewakili sama ada hendak membandingkan secara kongruen.
Kod sampel adalah seperti berikut:
$fruits = array("apple", "banana", "orange", "tomato"); $key = array_search("orange", $fruits); if ($key !== false) { echo "'orange' 的下标是: " . $key; } else { echo "'orange' 不存在!"; }
Hasil output ialah "Subskrip 'oren' ialah: 2".
3. Perbezaan antara fungsi in_array() dan array_search() fungsi
Walaupun fungsi in_array() dan array_search() mempunyai fungsi yang sama dalam menentukan sama ada sesuatu elemen wujud dalam tatasusunan, mereka Kedua-duanya masih mempunyai perbezaan berikut:
- Nilai pulangan adalah berbeza: in_array() mengembalikan nilai Boolean, array_search() mengembalikan subskrip elemen atau palsu.
- Kaedah perbandingan adalah berbeza: fungsi in_array() hanya membandingkan nilai elemen dan fungsi array_search() boleh membandingkan kedua-dua kunci dan nilai elemen.
- Sekatan penggunaan adalah berbeza: fungsi array_search() hanya boleh digunakan untuk tatasusunan satu dimensi, manakala fungsi in_array() boleh digunakan untuk tatasusunan berbilang dimensi.
4 Pelbagai cara untuk menentukan sama ada elemen wujud dalam tatasusunan
Selain fungsi in_array() dan array_search(), terdapat cara lain untuk menentukan sama ada sesuatu. elemen wujud dalam tatasusunan, seperti menggunakan fungsi isset() dan fungsi array_key_exists().
- Gunakan fungsi isset()
fungsi isset() boleh digunakan untuk menentukan sama ada unsur wujud dalam tatasusunan Kaedah penggunaan adalah seperti berikut:
$fruits = array("apple", "banana", "orange", "tomato"); if (isset($fruits[2])) { echo "'orange' 存在!"; } else { echo "'orange' 不存在!"; }
Outputnya ialah "'oren' wujud!".
- Gunakan fungsi array_key_exists()
fungsi array_key_exists() juga boleh digunakan untuk menentukan sama ada unsur wujud dalam tatasusunan Kaedah penggunaan adalah seperti berikut:
$fruits = array("apple", "banana", "orange", "tomato"); if (array_key_exists(2, $fruits)) { echo "'orange' 存在!"; } else { echo "'orange' 不存在!"; }
Keluarannya ialah "'oren' wujud!".
Tidak seperti fungsi isset() yang hanya boleh digunakan untuk menentukan sama ada nilai tatasusunan wujud atau kosong, fungsi array_key_exists() boleh digunakan untuk menentukan sama ada kunci tatasusunan wujud.
Kesimpulan
Melalui pengenalan di atas, kita dapat melihat bahawa dalam pembangunan PHP, tidak sukar untuk menentukan sama ada unsur wujud dalam tatasusunan Kita boleh menggunakan fungsi in_array(), array_search ( ) fungsi, isset() fungsi atau array_key_exists() fungsi, dsb. untuk mencapai ini. Kaedah mana yang hendak digunakan secara khusus, kita perlu memilih kaedah yang berbeza mengikut situasi yang berbeza untuk mencapai hasil yang terbaik.
Atas ialah kandungan terperinci PHP menentukan sama ada ia wujud dalam tatasusunan. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas

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

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

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

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

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

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

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,

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
