Dalam projek PHP, pilihan antara kaedah statik dan kaedah bukan statik (kaedah contoh) selalunya sukar. Terdapat situasi tertentu di mana penggunaan kaedah statik adalah lebih baik. Tetapi tidak banyak. Jadi statik atau tidak statik?
Salah satu kes yang paling biasa untuk menggunakan kaedah statik adalah untuk operasi "utiliti" yang tidak bergantung pada keadaan contoh. Contohnya, operasi manipulasi rentetan, pengiraan atau penukaran data. Kaedah ini tidak perlu mengakses sifat objek dan boleh dipanggil terus.
Mari kita ambil contoh klasik:
class StringHelper { public static function slugify(string $text): string { return strtolower(trim(preg_replace('/[^A-Za-z0-9-]+/', '-', $text))); } }
Dalam kes ini, kaedah slugify tidak memerlukan contoh untuk berfungsi. Jadi masuk akal untuk menggunakannya sebagai kaedah statik.
Apabila anda mempunyai fungsi yang perlu mudah diakses tanpa membuat contoh kelas, kaedah statik boleh digunakan untuk memudahkan kod. Contohnya, untuk kaedah pengesahan mudah, anda boleh membuat kelas statik yang menawarkan pengesahan ini.
Ini juga boleh menjadi sangat berguna untuk mengelakkan pertindihan kod. Daripada mencipta perkhidmatan yang akan disuntik di mana-mana hanya untuk memanggil satu atau dua fungsi utiliti, kaedah statik menjadikan penggunaan lebih langsung.
Kaedah statik boleh menjadi lebih cekap sedikit daripada kaedah contoh, kerana kaedah tersebut tidak memerlukan anda mencipta objek. Dalam konteks di mana prestasi adalah penting, dan kefungsian yang dipersoalkan adalah remeh dan tidak bernegara, kaedah statik boleh membuat semua perbezaan.
Walau bagaimanapun, peningkatan prestasi sering diabaikan, kecuali dalam kes penggunaan intensif.
Walaupun kelebihannya, kaedah statik bukanlah pilihan terbaik. Mereka mempunyai kelemahan, terutamanya dari segi kebolehujian. Kaedah statik adalah lebih sukar untuk dipermainkan dalam ujian unit, kerana ia mewujudkan pergantungan yang ketat yang tidak boleh digantikan dengan mudah dengan pelaksanaan palsu.
Dalam Symfony, yang berasaskan DI (suntikan kebergantungan), adalah lebih baik untuk menggunakan perkhidmatan bukan statik untuk mengekalkan kefleksibelan ujian dan mengikuti amalan seni bina perisian yang baik. Kecuali dalam kes-kes yang sangat kecil dan khusus yang dinyatakan di atas.
Penggunaan kaedah statik dalam projek Symfony sesuai untuk operasi mudah, tanpa kewarganegaraan dan berulang. Tetapi anda perlu sedar tentang hadnya, terutamanya dari segi kebolehujian dan fleksibiliti.
Kelebihan kaedah statik :
Kelemahan kaedah statik:
Untuk komponen yang lebih kompleks atau yang perlu berinteraksi dengan perkhidmatan lain, adalah lebih baik untuk menggunakan kaedah contoh dalam perkhidmatan dan mengambil kesempatan daripada bekas perkhidmatan dan suntikan kebergantungan Symfony.
Atas ialah kandungan terperinci Kaedah statik dalam projek PHP: idea yang baik atau yang buruk?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!