Maison  >  Article  >  Boucle sans fin pour la liste de tableaux remplie par l'utilisateur

Boucle sans fin pour la liste de tableaux remplie par l'utilisateur

WBOY
WBOYavant
2024-02-05 22:00:051201parcourir
Contenu de la question

Je dois écrire une méthode pour obtenir les spécifications de la voiture saisies par l'utilisateur et les ajouter à une liste de tableaux. Celui-ci doit accepter n'importe quel nombre de spécifications que l'utilisateur souhaite saisir, y compris aucune. C'est mon premier message ici, désolé pour toute mauvaise grammaire.

public static arraylist gettrim() {

scanner t = new scanner(system.in);
system.out.println("enter car trim");
arraylist<string> trim = new arraylist<>();

while (t.hasnext()) {
trim.add(t.next());
}

return trim;

}

Je pense que cette condition retournera false si un espace est saisi. Une telle itération continue ne peut être quittée que manuellement.

Je l'ai essayé aussi

if (t.hasNext()) {
trim.add(t.next());
}

else {
t.close();
}

Cela itère une fois et renvoie la liste de tableaux, mais je dois pouvoir en saisir davantage. Changer la condition if ou while en hasnextline() donne le même résultat, ici j'utilise hasnext() car le niveau de finition de la voiture a des attentes de formatage spécifiques. Je ne comprends pas pourquoi hasnext() ne renvoie pas false lorsqu'aucune entrée n'est donnée.


Bonne réponse


C'est... Non.

Pensez-y. Comment un ordinateur fait-il la différence entre un utilisateur qui réfléchit à ce qu'il doit taper et peut le laisser jusqu'après le déjeuner, et un utilisateur qui a « terminé » ? Allumez votre webcam et exécutez une analyse d'IA pour voir si l'utilisateur semble avoir fini de taper ?

system.in Pas un clavier. C'est "l'entrée standard du processus jvm", par défaut, et au moins, si vous lancez votre application java depuis la ligne de commande, configurez-la pour qu'elle lise depuis le clavier. Ce n’est pas obligatoire :

java -jar myapp.jar </some/path/to/some/file.txt

Maintenant system.in lit ce fichier. Le processus ne peut pas être lu à partir du clavier.

java -jar myapp.jar </dev/barcodescanner1

Maintenant, probablement chaque fois que vous scannez un code-barres, l'application Java recevra le code-barres comme si vous aviez saisi les chiffres du code-barres et appuyé sur "Entrée" 1.

Cela dépend de la "source de cette entrée" jusqu'à la "fin". Le fichier se termine lorsque la fin du fichier est atteinte.

Le clavier ne peut pas être "terminé" - donc, .hasnext() 不可能返回 false.

Vierge

Vous avez parlé de « saisir des espaces » dans vos commentaires.

Alors tu ne comprends passcanner. Vous êtes en bonne compagnie ; c’est probablement la chose la plus mal comprise. Si l’on regarde le nombre de questions inondant le stackoverflow, c’est effectivement le cas.

scanner n'a rien à voir avec le clavier .

Le scanner prend simplement n'importe quelle source de saisie de texte et la divise en morceaux. Les blocs sont appelés « jetons » et les « jetons » sont définis par « tout le texte entre délimiteurs ». Les délimiteurs sont eux-mêmes définis par des expressions régulières, l'expression régulière utilisée par défaut est s+. Par exemple, n'importe quelle quantité d'espace blanc.

Donc :

public static void main(string[] args) {
  scanner s = new scanner(system.in);
  while (true) {
    system.out.println("token: ≥" + s.next()) + "≤");
  }
}

Si vous exécutez cette commande et tapez : hello world!,然后按 enter 键,并输入 my name is lajos dans la ligne de commande, vous verrez :

token: ≥hello≤
token: ≥world!≤
token: ≥my≤
token: ≥name≤
token: ≥is≤
token: ≥lajos≤

À propos du scanner : Il n'est pas possible de s'inscrire ou d'obtenir le contenu de quoi que ce soit sous le "séparateur". Vous ne pouvez pas demander au scanner : combien y a-t-il de blancs ?

Vous ne pouvez pas non plus demander : « Stop » lorsque vous rencontrez un espace. Non, les espaces séparent simplement un jeton du suivant. Pour les scanners, il n'y a aucune différence entre appuyer sur la touche Entrée et appuyer sur la barre d'espace puis sur la touche Entrée. Il s'agit uniquement de "1 ou plusieurs caractères d'espacement" et sont donc interchangeables et ne peuvent pas être détectés puisqu'il s'agit de délimiteurs.

Vous ne voudrez peut-être pas du tout utiliser de scanner. system.in lui-même peut certainement le différencier.

Solution 1

Une stratégie courante consiste à mentionner un mot magique qui signifie « terminé » dans l'invite. Par exemple :

static void main(string[] args) throws exception {
  var s = new scanner(system.in);
  system.out.println("welcome to the fruit stand! enter the fruit you'd like to buy, one at a time:");

  var basket = new arraylist<string>();
  while (true) {
    system.out.print("fruit (type 'done' when done): ");
    string fruit = s.next();
    if (fruit.equalsignorecase("done")) break;
    basket.add(fruit);
  }

  system.out.println("here's your basket: " + basket);
}

Solution 2

Scanner de tranchées. Ou au moins, laissez tout tomber et utilisez simplement nextline, qui interagit nextline,它与它拥有的所有其他方法的交互非常 - 选择一个且仅一个(nextline,或除 nextlinetrès

avec toutes les autres méthodes dont il dispose - choisissez-en une et une seule (nextline, ou sauf nextline) :

static void main(string[] args) throws exception {
  var s = new scanner(system.in);
  system.out.println("welcome to the fruit stand! enter the fruit you'd like to buy, one at a time:");

  var basket = new arraylist<string>();
  while (true) {
    system.out.print("fruit (enter when done): ");
    string fruit = s.nextline();
    if (fruit.isempty()) break;
    basket.add(fruit);
  }

  system.out.println("here's your basket: " + basket);
}
/dev[1] En fait, la plupart des lecteurs de codes-barres ressemblent et agissent comme des claviers et n'ont pas de périphérique car il n'existe pas dans

/ et ne peuvent pas être intégrés à un tel processus. Mais, à titre d’exemple, ça marche.

Vous pouvez essayer ceci :🎜
public static ArrayList getTrim() {

Scanner t = new Scanner(System.in);
System.out.println("Enter car trim");
ArrayList<String> trim = new ArrayList<>();

while (t.hasNext()) {

if (!t.next().trim().equals("") {

trim.add(t.next());
      }

else {
t.close();
      }
   }

return trim;

}

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!

Déclaration:
Cet article est reproduit dans:. en cas de violation, veuillez contacter admin@php.cn Supprimer