Jadilah Imperatif!!
TL;DR: Fungsi dengan nama yang tidak jelas menyembunyikan niat dan mengelirukan pembaca. Gunakan nama deskriptif, berorientasikan tindakan.
Fungsi yang dinamakan dengan istilah generik memaksa pembaca untuk menyelami pelaksanaan untuk memahami tingkah laku mereka.
Ini membuang masa dan meningkatkan kemungkinan ralat.
Penamaan menjadi lebih kritikal apabila berfungsi dengan fungsi kendiri, di mana nama kelas tidak memberikan konteks tambahan.
Isu ini secara langsung berkaitan dengan prinsip Tell, Don’t Ask.
Daripada mendedahkan gelagat samar-samar yang memaksa pemanggil membuat kesimpulan kefungsian, nama penting menyampaikan tindakan yang tepat, membimbing pembaca tanpa perlu memeriksa kod.
Apabila anda menamakan fungsi secara deskriptif, anda menghapuskan tekaan yang tidak perlu dan selaras dengan prinsip ini.
public String dateFormatting(Date date) { return new SimpleDateFormat("yyyy-MM-dd").format(date); } public void load() { System.out.println("Loading..."); }
public String formatDate(Date date) { return new SimpleDateFormat("yyyy-MM-dd").format(date); } public void loadUserPreferences() { System.out.println("Loading user preferences..."); }
[X] Manual
Anda boleh mengesan bau ini dengan menyemak nama fungsi yang menggunakan istilah yang tidak jelas seperti do, run, proses, muat, dsb.
Linter automatik boleh membenderakan corak ini atau menyerlahkan fungsi dengan nama yang terlalu generik.
[X] Pemula
Nama fungsi harus mencipta surat-menyurat satu sama satu yang jelas antara nama dan fungsinya.
Memecahkan Bijection ini memaksa pembangun untuk memeriksa butiran kod untuk konteks, memperlahankan penyahpepijatan, ulasan dan sambungan.
Alat AI kadangkala menjana nama fungsi generik tanpa memahami domain anda.
Apabila menggunakan AI, nyatakan bahawa nama fungsi mestilah deskriptif dan berorientasikan tindakan.
Model AI boleh membantu mengesan nama yang tidak jelas dengan membandingkan tandatangan fungsi dengan amalan terbaik penamaan yang telah ditetapkan.
Menggabungkan AI dengan semakan kod manual menghasilkan hasil yang terbaik.
Ingat: AI Assistants melakukan banyak kesilapan
Without Proper Instructions | With Specific Instructions |
---|---|
ChatGPT | ChatGPT |
Claude | Claude |
Perplexity | Perplexity |
Copilot | Copilot |
Gemini | Gemini |
Nama fungsi bukan sekadar label; mereka adalah kontrak dengan pembaca.
Nama yang samar-samar melanggar kontrak ini dan membawa kepada kekeliruan.
Nama deskriptif, berorientasikan tindakan memudahkan komunikasi dan menjadikan kod anda lebih mudah untuk diselenggara dan dilanjutkan.
Bau Kod adalah pendapat saya.
Foto oleh britishlibrary di Unsplash
Nama fungsi hendaklah kata kerja atau frasa kata kerja, dan ia perlu
bermakna
Robert C. Martin
Artikel ini adalah sebahagian daripada Siri CodeSmell.
Atas ialah kandungan terperinci Bau Kod - Nama Fungsi Bukan Imperatif. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!