La méthode nextLine() de Java, définie dans la classe java.util.Scanner, est couramment utilisée pour lire des lignes de texte à partir d'une entrée standard (le clavier de l'utilisateur). Cependant, son utilisation dans certains scénarios peut entraîner un comportement inattendu.
Considérons l'exemple suivant où nextLine() est utilisé dans une boucle de menu :
Scanner scanner = new Scanner(System.in); while (true) { // Display menu options // ... System.out.print("Please enter your selection: "); int selection = scanner.nextInt(); if (selection == 1) { // This issue arises here when reading a sentence System.out.print("Enter a sentence: "); String sentence = scanner.nextLine(); } // ... }
Lorsque ce code s'exécute, il échoue pour demander à l'utilisateur une phrase lorsque l'utilisateur saisit la valeur 1. Au lieu de cela, le code passe directement à l'invite de saisie suivante pour un index.
La raison de ce comportement réside dans la nature de nextLine(). Lorsqu'il est utilisé après nextInt(), il lit et consomme le caractère de nouvelle ligne restant (n) dans le flux d'entrée. Par conséquent, lorsque nextLine() est invoqué pour lire la phrase, il rencontre un tampon d'entrée vide et renvoie une chaîne vide.
Pour résoudre ce problème, il est nécessaire de consommer explicitement le caractère de nouvelle ligne en utilisant scanner.nextLine( ) après chaque scanner.nextInt(). Cela garantit que le tampon d'entrée est effacé et que nextLine() peut lire correctement l'entrée de l'utilisateur pour la phrase.
En suivant ces directives, vous pouvez éviter les incohérences lors de l'utilisation de nextLine() et vous assurer que votre code gère avec précision l'utilisateur. saisie dans les scénarios à passage unique et multiple.
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!