Rumah  >  Artikel  >  pembangunan bahagian belakang  >  Fungsi baharu dalam PHP8: teknik carian rentetan yang cekap untuk str_contains()

Fungsi baharu dalam PHP8: teknik carian rentetan yang cekap untuk str_contains()

WBOY
WBOYasal
2023-05-16 11:40:52883semak imbas

PHP8 sudah pasti merupakan versi PHP yang penting pada masa ini Selain membawa prestasi dan keselamatan yang lebih baik, ia juga memperkenalkan beberapa ciri baharu yang sangat berguna. Salah satu ciri baharu ialah fungsi str_contains(), yang digunakan untuk mencari subrentetan tertentu dalam rentetan.

Pada masa lalu, kami biasanya menggunakan fungsi strpos() untuk mencari sama ada subrentetan tertentu wujud dalam rentetan. Contohnya, untuk mencari sama ada rentetan berikut mengandungi subrentetan "hello":

$string = "Hello, world!";
if (strpos($string, "hello") !== false) {
    echo "Found 'hello' in the string!";
} else {
    echo "Did not find 'hello' in the string!";
}

Hasilnya ialah "Tidak menemui 'hello' dalam rentetan!". Ini kerana fungsi strpos() adalah sensitif huruf besar-besaran.

Fungsi str_contains() tidak sensitif huruf besar dan kecil Ia mengembalikan nilai Boolean secara langsung yang menunjukkan sama ada rentetan mengandungi subrentetan yang ditentukan. Oleh itu, kod di atas boleh ditulis semula menggunakan fungsi str_contains():

$string = "Hello, world!";
if (str_contains($string, "hello")) {
    echo "Found 'hello' in the string!";
} else {
    echo "Did not find 'hello' in the string!";
}

Hasilnya ialah "Temui 'hello' dalam rentetan!". Oleh kerana fungsi str_contains() akan mencari sama ada rentetan itu mengandungi subrentetan "hello", ia tidak akan menjadi sensitif huruf besar-besaran.

Menggunakan str_contains() dan bukannya strpos() bukan sahaja lebih intuitif, tetapi juga lebih cekap. Kerana str_contains() akan menggunakan beberapa teknik pengoptimuman untuk meningkatkan kecekapan carian rentetan. Teknik pengoptimuman ini termasuk:

Pengoptimuman 1: Gunakan algoritma Boyer-Moore

Algoritma Boyer-Moore ialah algoritma carian rentetan yang cekap, yang merupakan salah satu pelaksanaan asas str_contains() fungsi. Idea utama algoritma Boyer-Moore adalah untuk melangkau seberapa banyak aksara yang tidak sah yang mungkin untuk mengurangkan bilangan carian.

Sebagai contoh, apabila mencari kedudukan rentetan "hello" dalam "hello, world!", algoritma Boyer-Moore akan mula memadankan daripada aksara terakhir "o" rentetan itu. Jika tiada padanan, jarak lompatan dikira berdasarkan bilangan kejadian watak. Dalam contoh ini, aksara "o" muncul dua kali dalam rentetan "hello", jadi algoritma Boyer-Moore akan melangkau kedudukan carian ke hadapan dengan dua aksara untuk mengelakkan padanan berulang.

Menggunakan algoritma Boyer-Moore boleh meningkatkan kecekapan carian rentetan, terutamanya bagi rentetan yang lebih panjang dan subrentetan yang lebih panjang.

Pengoptimuman 2: Elakkan menyalin rentetan beberapa kali

Apabila mencari rentetan menggunakan fungsi strpos(), anda biasanya perlu menyalin rentetan dan subrentetan untuk perbandingan. Ini boleh menyebabkan peningkatan penggunaan memori, terutamanya apabila rentetan yang dikendalikan adalah panjang.

Fungsi str_contains() mengelakkan penyalinan rentetan beberapa kali dengan menggunakan mekanisme pengiraan rujukan. Mekanisme pengiraan rujukan ialah teknologi pengurusan memori yang boleh berkongsi salinan rentetan yang sama apabila berbilang pembolehubah merujuk kepada rentetan yang sama untuk mengelakkan berbilang salinan.

Menggunakan mekanisme pengiraan rujukan boleh mengelakkan penyalinan rentetan beberapa kali, dengan itu mengurangkan penggunaan memori dan meningkatkan prestasi program.

Pengoptimuman 3: Dilaksanakan menggunakan kod C

Fungsi str_contains() dilaksanakan menggunakan kod C, jadi ia lebih pantas dan lebih cekap daripada fungsi strpos(). Apabila mencari sebilangan besar rentetan, menggunakan fungsi str_contains() boleh meningkatkan kelajuan pelaksanaan program dengan banyak.

Ringkasan

Fungsi str_contains() ialah fungsi baharu yang sangat berguna dalam PHP8, yang boleh digunakan untuk mencari subrentetan tertentu dalam rentetan. Ia bukan sahaja menjadikan kod kami lebih intuitif dan lebih mudah difahami, tetapi juga meningkatkan prestasi program melalui penggunaan teknik pengoptimuman.

Jika anda perlu melakukan carian rentetan dalam PHP, pertimbangkan untuk menggunakan fungsi str_contains() untuk prestasi yang lebih baik dan kod yang lebih cekap.

Atas ialah kandungan terperinci Fungsi baharu dalam PHP8: teknik carian rentetan yang cekap untuk str_contains(). Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
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