Odeur de code - Noms des fonctions non impératives
Soyez impératif !!
TL;DR : les fonctions dont les noms ne sont pas clairs cachent l'intention et confondent les lecteurs. Utilisez des noms descriptifs et orientés vers l'action.
Problèmes
- Objectif de la fonction peu clair
- Augmentation de la charge cognitive
- Contexte trompeur
- Lisibilité réduite
- Collaboration difficile
- Fonctionnalité cachée
Solutions
- Utilisez des verbes orientés vers l'action
- Rendre les noms descriptifs
- Refléter l'objectif de la fonction
- Évitez les termes génériques
- Fournir un contexte significatif
- Exprimer clairement la responsabilité unique
- Faites correspondre l'action au résultat
Refactorisations

Refactoring 005 - Remplacer le commentaire par le nom de la fonction
Maxi Contieri ・ 7 juin 22
Contexte
Les fonctions nommées avec des termes génériques obligent les lecteurs à se plonger dans l'implémentation pour comprendre leur comportement.
Cela fait perdre du temps et augmente les risques d'erreurs.
La dénomination devient encore plus critique lorsque vous travaillez avec des fonctions autonomes, où le nom de la classe ne fournit pas de contexte supplémentaire.
Ce problème est directement lié au Principe « Dites, ne demandez pas ».
Au lieu d'exposer des comportements ambigus qui obligent l'appelant à déduire des fonctionnalités, les noms impératifs transmettent l'action exacte, guidant le lecteur sans avoir besoin d'inspecter le code.
Lorsque vous nommez les fonctions de manière descriptive, vous éliminez les conjectures inutiles et vous vous alignez sur ce principe.
Exemple de code
Faux
public String dateFormatting(Date date) { return new SimpleDateFormat("yyyy-MM-dd").format(date); } public void load() { System.out.println("Loading..."); }
Droite
public String formatDate(Date date) { return new SimpleDateFormat("yyyy-MM-dd").format(date); } public void loadUserPreferences() { System.out.println("Loading user preferences..."); }
Détection
[X] Manuel
Vous pouvez détecter cette odeur en examinant les noms de fonctions qui utilisent des termes vagues comme do, run, processus, load, etc. .
Les linters automatisés peuvent signaler ces modèles ou mettre en évidence des fonctions avec des noms trop génériques.
Balises
- Nommer
Niveau
[X] Débutant
Pourquoi la bijection est importante
Les noms de fonctions doivent créer une correspondance claire et univoque entre leur nom et leur fonctionnalité.
Briser cette bijection oblige les développeurs à examiner les détails du code pour le contexte, ce qui ralentit le débogage, les révisions et les extensions.
Génération d'IA
Les outils d'IA génèrent parfois des noms de fonctions génériques sans comprendre votre domaine.
Lorsque vous utilisez l'IA, précisez que les noms de fonctions doivent être descriptifs et orientés vers l'action.
Détection IA
Les modèles d'IA peuvent aider à détecter les noms ambigus en comparant les signatures de fonction avec les meilleures pratiques de dénomination prédéfinies.
La combinaison de l'IA avec la révision manuelle du code donne les meilleurs résultats.
Essayez-les !
Rappelez-vous : les assistants IA font beaucoup d'erreurs
Without Proper Instructions | With Specific Instructions |
---|---|
ChatGPT | ChatGPT |
Claude | Claude |
Perplexity | Perplexity |
Copilot | Copilot |
Gemini | Gemini |
Conclusion
Les noms de fonctions ne sont pas de simples étiquettes ; ce sont des contrats avec le lecteur.
Les noms ambigus rompent ce contrat et prêtent à confusion.
Les noms descriptifs et orientés vers l'action simplifient la communication et facilitent la maintenance et l'extension de votre code.
Rapports

Code Odeur 33 - Abréviations
Maxi Contieri ・ 24 novembre 2020

Code Odeur 153 - Noms trop longs
Maxi Contieri ・ 29 juillet 22

Code Smell 38 - Noms abstraits
Maxi Contieri ・ 30 novembre 2020

Code Smell 174 - Nom de la classe dans les attributs
Maxi Contieri ・ 29 octobre 22
Voir aussi

Qu'est-ce qu'un nom exactement ? — Partie I : La quête
Maxi Contieri ・ 9 février 21

Qu'est-ce qu'un nom exactement - Partie II Réadaptation
Maxi Contieri ・ 23 mai '21
Clause de non-responsabilité
Les odeurs de code sont mon opinion.
Crédits
Photo par britishlibrary sur Unsplash
Un nom de fonction doit être un verbe ou une phrase verbale, et il doit l'être
significatif
Robert C. Martin

Citations intéressantes sur le génie logiciel
Maxi Contieri ・ 28 décembre 20
Cet article fait partie de la série CodeSmell.

Comment trouver les parties puantes de votre code
Maxi Contieri ・ 21 mai '21
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds

Remplacer les caractères de chaîne en javascript

jQuery Vérifiez si la date est valide

jQuery obtient un rembourrage / marge d'élément

10 vaut la peine de vérifier les plugins jQuery

Http débogage avec le nœud et le http-console

Tutoriel de configuration de l'API de recherche Google personnalisé

jQuery Ajouter une barre de défilement à div
