Karat - Output Input

Bab ini membahas cara menerima nilai dari input standar (keyboard) dan nilai tampilan ke output standar (konsol). Dalam bab ini, kita juga akan membahas argumen baris perintah yang lewat.

Jenis Pembaca dan Penulis

Fitur pustaka standar Rust untuk input dan output diatur di sekitar dua ciri -

  • Read
  • Write
Sr Tidak Sifat & Deskripsi Contoh
1

Read

Jenis yang mengimplementasikan Baca memiliki metode untuk input berorientasi byte. Mereka disebut pembaca

Stdin, Berkas
2

Write

Jenis yang mengimplementasikan Write mendukung keluaran teks berorientasi byte dan UTF-8. Mereka disebut penulis.

Stdout, File

Baca Sifat

Readersadalah komponen yang byte dari program Anda dapat dibaca. Contohnya termasuk membaca input dari keyboard, file, dllread_line() Metode sifat ini dapat digunakan untuk membaca data, satu baris pada satu waktu, dari file atau aliran input standar.

Sr Tidak Sifat Metode & Deskripsi
1 Baca

read_line(&mut line)->Result

Membaca sebaris teks dan menambahkannya ke baris, yang merupakan String. Nilai yang dikembalikan adalah io :: Result, jumlah byte yang dibaca.

Ilustrasi - Membaca dari Konsol - stdin ()

Program Rust mungkin harus menerima nilai dari pengguna saat runtime. Contoh berikut membaca nilai dari input standar (Keyboard) dan mencetaknya ke konsol.

fn main(){
   let mut line = String::new();
   println!("Enter your name :");
   let b1 = std::io::stdin().read_line(&mut line).unwrap();
   println!("Hello , {}", line);
   println!("no of bytes read , {}", b1);
}

Fungsi stdin () mengembalikan pegangan ke aliran input standar dari proses saat ini, di mana fungsi read_line dapat diterapkan. Fungsi ini mencoba membaca semua karakter yang ada dalam buffer input ketika bertemu dengan karakter akhir baris.

Keluaran

Enter your name :
Mohtashim
Hello , Mohtashim
no of bytes read , 10

Tulis Sifat

Writersadalah komponen yang program Anda dapat menulis byte. Contohnya termasuk nilai pencetakan ke konsol, menulis ke file, dll. Metode write () dari sifat ini dapat digunakan untuk menulis data ke file atau aliran keluaran standar.

Sr Tidak Sifat Metode & Deskripsi
1 Menulis

write(&buf)->Result

Menulis beberapa byte dalam slice buf ke aliran yang mendasarinya. Ini mengembalikan io :: Result, jumlah byte yang ditulis.

Ilustrasi - Menulis ke Konsol - stdout ()

The cetak! atau println! makro dapat digunakan untuk menampilkan teks di konsol. Namun, Anda juga bisa menggunakan fungsi pustaka standar write () untuk menampilkan beberapa teks ke keluaran standar.

Mari kita pertimbangkan contoh untuk memahami ini.

use std::io::Write;
fn main() {
   let b1 = std::io::stdout().write("Tutorials ".as_bytes()).unwrap();
   let b2 = std::io::stdout().write(String::from("Point").as_bytes()).unwrap();
   std::io::stdout().write(format!("\nbytes written {}",(b1+b2)).as_bytes()).unwrap();
}

Keluaran

Tutorials Point
bytes written 15

The stdout () fungsi perpustakaan standar kembali pegangan untuk standar keluaran dari proses saat ini, dimanawritefungsi dapat diterapkan. Metode write () mengembalikan enum, Result. The unwrap () adalah metode pembantu untuk mengekstrak hasil aktual dari enumerasi. Metode buka bungkus akan membuat panik jika terjadi kesalahan.

NOTE - File IO dibahas di bab berikutnya.

Argumen CommandLine

Argumen CommandLine diteruskan ke program sebelum menjalankannya. Mereka seperti parameter yang diteruskan ke fungsi. Parameter CommandLine dapat digunakan untuk meneruskan nilai ke fungsi main () . Itustd::env::args() mengembalikan argumen baris perintah.

Ilustrasi

Contoh berikut meneruskan nilai sebagai argumen commandLine ke fungsi main (). Program ini dibuat dalam nama file main.rs .

//main.rs
fn main(){
   let cmd_line = std::env::args();
   println!("No of elements in arguments is :{}",cmd_line.len()); 
   //print total number of values passed
   for arg in cmd_line {
      println!("[{}]",arg); //print all values passed 
      as commandline arguments
   }
}

Program ini akan menghasilkan file main.exe setelah dikompilasi. Beberapa parameter baris perintah harus dipisahkan dengan spasi. Jalankan main.exe dari terminal sebagai main.exe halo tutorialspoint .

NOTE- halo dan tutorialspoint adalah argumen baris perintah.

Keluaran

No of elements in arguments is :3
[main.exe]
[hello]
[tutorialspoint]

Outputnya menunjukkan 3 argumen karena main.exe adalah argumen pertama.

Ilustrasi

Program berikut menghitung jumlah nilai yang diteruskan sebagai argumen baris perintah. Sebuah daftar nilai integer dipisahkan oleh spasi diteruskan ke program.

fn main(){
   let cmd_line = std::env::args();
   println!("No of elements in arguments is 
   :{}",cmd_line.len()); 
   // total number of elements passed

   let mut sum = 0;
   let mut has_read_first_arg = false;

   //iterate through all the arguments and calculate their sum

   for arg in cmd_line {
      if has_read_first_arg { //skip the first argument since it is the exe file name
         sum += arg.parse::<i32>().unwrap();
      }
      has_read_first_arg = true; 
      // set the flag to true to calculate sum for the subsequent arguments.
   }
   println!("sum is {}",sum);
}

Saat menjalankan program sebagai main.exe 1 2 3 4, hasilnya adalah -

No of elements in arguments is :5
sum is 10