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