Pourquoi l'optionnel de Java 8 ne devrait pas être utilisé comme argument de méthode
Bien que l'optionnel de Java 8 soit conçu comme un type de retour, son utilisation comme méthode Les arguments ont soulevé un certain débat. Voici une analyse concise du problème :
Raison d'être pour éviter les arguments facultatifs
-
Complexité inutile : L'utilisation d'arguments facultatifs introduit une logique conditionnelle dans méthodes, qui peuvent être contre-productives.
-
Compilateur Inefficacités : L'encapsulation facultative implique un boxing inutile des arguments, ce qui a un impact sur les performances du compilateur.
-
Augmentation de la surcharge de mémoire : Les paramètres facultatifs consomment plus de mémoire que leurs équivalents nullables.
-
Risque de références nulles : Passer Facultatif comme null dans les paramètres réels est un potentiel problème.
-
Déséquilibre du flux de données : Facultatif gère deux états (présent et vide), qui doivent être séparés lorsqu'ils sont utilisés comme entrée, créant une complexité de flux de données.
Approches alternatives
Au lieu d'utiliser des arguments facultatifs, considérez ce qui suit alternatives :
-
Autoriser les paramètres nullables : Utilisez des paramètres nullables (par exemple, String p1, BigDecimal p2) pour indiquer des valeurs nulles potentielles et incluez des descriptions Javadoc claires.
-
Fournir des méthodes surchargées : Créez plusieurs méthodes surchargées avec des combinaisons d'arguments spécifiques pour éviter de longues déclarations conditionnelles. (par exemple, calculerSomething(String p1), calculerSomething(BigDecimal p2), calculerSomething(String p1, BigDecimal p2))
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!