Rumah >Java >Gelung tidak berkesudahan untuk senarai tatasusunan yang dihuni pengguna

Gelung tidak berkesudahan untuk senarai tatasusunan yang dihuni pengguna

WBOY
WBOYke hadapan
2024-02-05 22:00:051358semak imbas
Kandungan soalan

Saya perlu menulis kaedah untuk mendapatkan spesifikasi kereta yang dimasukkan oleh pengguna dan menambahnya ke senarai tatasusunan. Ini perlu menerima sebarang bilangan spesifikasi yang ingin dimasukkan oleh pengguna, termasuk tiada. Ini adalah post pertama saya di sini, mohon maaf atas sebarang tatabahasa yang tidak baik.

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;

}

Saya rasa syarat ini akan kembali palsu jika ruang dimasukkan. Lelaran berterusan sedemikian hanya boleh dikeluarkan secara manual.

Saya pun mencubanya

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

else {
t.close();
}

Ini berulang sekali dan mengembalikan senarai tatasusunan, tetapi saya perlu dapat memasukkan lebih banyak lagi. Menukar syarat if atau while kepada hasnextline() memberikan hasil yang sama, di sini saya menggunakan hasnext() kerana tahap trim kereta mempunyai jangkaan pemformatan tertentu. Saya tidak faham mengapa hasnext() tidak mengembalikan false apabila tiada input diberikan.


Jawapan betul


Ia..Tidak.

Fikir-fikirkanlah. Bagaimanakah komputer membezakan antara pengguna yang berfikir tentang perkara yang hendak ditaip dan mungkin meninggalkannya sehingga selepas makan tengah hari, dan pengguna yang "selesai"? Nyalakan kamera web anda dan jalankan beberapa analisis AI untuk melihat sama ada pengguna kelihatanseperti mereka telah selesai menaip?

system.in Bukan papan kekunci. Ia adalah "input standard proses jvm", default, dan sekurang-kurangnya, jika anda melancarkan aplikasi java anda dari baris arahan, tetapkan ia untuk dibaca dari papan kekunci. Ia tidak semestinya:

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

Sekarang system.in membaca dari fail ini. Proses tidak boleh dibaca dari papan kekunci.

java -jar myapp.jar </dev/barcodescanner1

Sekarang, mungkin setiap kali anda mengimbas kod bar, aplikasi java akan menerima kod bar sama seperti anda memasukkan digit kod bar dan menekan "Enter" 1.

Ia bergantung kepada "sumber input ini" hingga ke "hujung". Fail tamat apabila hujung fail dicapai.

Papan kekunci tidak boleh "over" - jadi, .hasnext() 不可能返回 false.

Kosong

Anda bercakap tentang "memasuki ruang" dalam ulasan anda.

Maka kamu tidak fahamscanner. Anda berada dalam syarikat yang baik; ini mungkin perkara yang paling salah faham. Jika kita melihat bilangan soalan yang membanjiri stackoverflow, ini memang berlaku.

scanner tiada kaitan dengan papan kekunci .

Pengimbas hanya mengambil sebarang sumber input teks dan membahagikannya kepada beberapa bahagian. Blok dipanggil "token", dan "token" ditakrifkan oleh "semua teks antara pembatas". Pembatas pula ditakrifkan oleh ungkapan biasa, ungkapan biasa yang digunakan secara lalai ialah s+. Sebagai contoh, sebarang jumlah ruang putih.

Oleh itu:

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

Jika anda menjalankan arahan ini dan taip: hello world!,然后按 enter 键,并输入 my name is lajos dalam baris arahan, anda akan melihat:

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

Perkara tentang pengimbas: Tidak boleh untuk mendaftar atau sebaliknya mendapatkan kandungan apa-apa di bawah "pemisah". Anda tidak boleh bertanya kepada pengimbas: Berapa banyak kosong yang ada?

Anda juga tidak boleh bertanya: "Berhenti" apabila anda menemui ruang. Tidak, ruang hanya memisahkan satu token daripada yang seterusnya. Untuk pengimbas, terdapat tiada perbezaan antara menekan kekunci enter dan menekan bar ruang dan kemudian kekunci enter. Ini semua ialah "1 atau lebih aksara ruang putih" jadi boleh ditukar ganti dan tidak boleh dikesan kerana ini mengenai pembatas.

Anda mungkin tidak mahu menggunakan pengimbas sama sekali. sistem.dengan sendirinya pasti dapat membezakannya.

Penyelesaian 1

Strategi biasa ialah menyebut beberapa perkataan ajaib yang bermaksud "selesai" dalam gesaan. Contohnya:

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);
}

Penyelesaian 2

Pengimbas Parit. Atau sekurang-kurangnya, lepaskan semuanya dan hanya gunakan nextline, yang berinteraksi nextline,它与它拥有的所有其他方法的交互非常 - 选择一个且仅一个(nextline,或除 nextlinesangat

dengan semua kaedah lain yang ada - pilih satu dan hanya satu (nextline, atau kecuali baris seterusnya):

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] Sebenarnya, kebanyakan pengimbas kod bar kelihatan dan bertindak seperti papan kekunci dan tidak mempunyai peranti kerana ia tidak wujud dalam

/ dan tidak boleh disalurkan ke dalam proses sedemikian. Tetapi, sebagai contoh, ia berfungsi.

Anda boleh mencuba ini:🎜
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;

}

Atas ialah kandungan terperinci Gelung tidak berkesudahan untuk senarai tatasusunan yang dihuni pengguna. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Artikel ini dikembalikan pada:stackoverflow.com. Jika ada pelanggaran, sila hubungi admin@php.cn Padam