Pas - Giriş Çıkışı

Bu bölümde, standart girişten (klavye) değerlerin nasıl kabul edileceği ve değerlerin standart çıkışa (konsol) nasıl gösterileceği anlatılmaktadır. Bu bölümde, komut satırı argümanlarının aktarılmasını da tartışacağız.

Okuyucu ve Yazar Türleri

Rust'un girdi ve çıktı için standart kitaplık özellikleri iki özellik etrafında düzenlenmiştir -

  • Read
  • Write
Sr.No Özellik ve Açıklama Misal
1

Read

Read'i uygulayan türler, bayt yönelimli girdi için yöntemlere sahiptir. Onlara okuyucu denir

Stdin, Dosya
2

Write

Yazma uygulayan türler hem bayt yönelimli hem de UTF-8 metin çıktısını destekler. Onlara yazar denir.

Stdout, Dosya

Özelliği Oku

Readersprogramınızın baytları okuyabileceği bileşenlerdir. Örnekler arasında klavyeden, dosyalardan vb. Giriş okuma yer alır.read_line() Bu özelliğin yöntemi, bir dosyadan veya standart giriş akışından her seferinde bir satır veri okumak için kullanılabilir.

Sr.No Kişisel özellik Yöntem ve Açıklama
1 Okuyun

read_line(&mut line)->Result

Bir metin satırını okur ve onu bir Dize olan satıra ekler. Dönüş değeri bir io :: Result'dur, okunan bayt sayısıdır.

Resim - Konsoldan Okuma - stdin ()

Rust programları, çalışma zamanında kullanıcıdan gelen değerleri kabul etmek zorunda kalabilir. Aşağıdaki örnek, standart girişten (Klavye) değerler okur ve bunu konsola yazdırır.

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

Stdin () işlev olduğu geçerli işlem, standart giriş akımı için bir tanıtıcı döndürür read_line fonksiyonu uygulanabilir. Bu işlev, bir satır sonu karakteriyle karşılaştığında girdi arabelleğinde bulunan tüm karakterleri okumaya çalışır.

Çıktı

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

Yazma Özelliği

Writersprogramınızın bayt yazabileceği bileşenlerdir. Örnekler, değerleri konsola yazdırma, dosyalara yazma, vb. İçerir. Bu özelliğin write () yöntemi, bir dosyaya veya standart çıktı akışına veri yazmak için kullanılabilir.

Sr.No Kişisel özellik Yöntem ve Açıklama
1 Yazmak

write(&buf)->Result

Dilim tampondaki bazı baytları temel alınan akışa yazar. Yazılan bayt sayısı olan io :: Result döndürür.

Çizim - Konsola Yazma - stdout ()

Baskı! veya println! konsolda metin görüntülemek için makrolar kullanılabilir. Bununla birlikte, standart çıktıya bazı metinleri görüntülemek için write () standart kitaplık işlevini de kullanabilirsiniz .

Bunu anlamak için bir örnek ele alalım.

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

Çıktı

Tutorials Point
bytes written 15

Stdout'u () standart kütüphane işlevi, mevcut işlemin standart çıkış akışı için bir tanıtıcı döndürür hangiwriteişlevi uygulanabilir. Write () yöntemi bir enum, Result döndürür. Wrrap (), numaralandırmadan gerçek sonucu çıkarmak için yardımcı bir yöntemdir. Çözme yöntemi, bir hata oluşursa panik gönderir.

NOTE - Dosya GÇ'si sonraki bölümde tartışılacaktır.

CommandLine Bağımsız Değişkenleri

CommandLine argümanları, çalıştırılmadan önce bir programa aktarılır. Fonksiyonlara aktarılan parametreler gibidirler. CommandLine parametreleri, değerleri main () işleve geçirmek için kullanılabilir . std::env::args() komut satırı argümanlarını döndürür.

İllüstrasyon

Aşağıdaki örnek, değerleri main () işlevine commandLine bağımsız değişkenleri olarak iletir. Program, main.rs dosya adıyla oluşturulur .

//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, derlendikten sonra bir main.exe dosyası oluşturacaktır . Birden çok komut satırı parametresi boşlukla ayrılmalıdır. Terminalden main.exe'yi main.exe hello öğretici noktası olarak çalıştırın .

NOTE- merhaba ve öğretici nokta komut satırı argümanlarıdır.

Çıktı

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

Main.exe ilk bağımsız değişken olduğu için çıktı 3 bağımsız değişken gösterir .

İllüstrasyon

Aşağıdaki program, komut satırı argümanları olarak aktarılan değerlerin toplamını hesaplar. Programa boşlukla ayrılmış bir tamsayı değerleri listesi aktarılır.

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

Programı main.exe 1 2 3 4 olarak çalıştırdığınızda, çıktı -

No of elements in arguments is :5
sum is 10