Keyboard shortcuts

Press or to navigate between chapters

Press S or / to search in the book

Press ? to show this help

Press Esc to hide this help

Ранні повернення

У попередньому прикладі ми явно обробляли помилки за допомогою комбінацій. Інший спосіб впоратися з цим аналізом випадків — використовувати комбінацію операторів match і ранніх повернень.

Тобто ми можемо просто припинити виконання функції та повернути помилку, якщо вона виникає. Для деяких такий спосіб коду може бути простішим і для читання, і для написання. Розгляньте цю версію попереднього прикладу, переписану з використанням ранніх повернень:

use std::num::ParseIntError;

fn multiply(first_number_str: &str, second_number_str: &str) -> Result<i32, ParseIntError> {
    let first_number = match first_number_str.parse::<i32>() {
        Ok(first_number)  => first_number,
        Err(e) => return Err(e),
    };

    let second_number = match second_number_str.parse::<i32>() {
        Ok(second_number)  => second_number,
        Err(e) => return Err(e),
    };

    Ok(first_number * second_number)
}

fn print(result: Result<i32, ParseIntError>) {
    match result {
        Ok(n)  => println!("n is {}", n),
        Err(e) => println!("Error: {}", e),
    }
}

fn main() {
    print(multiply("10", "2"));
    print(multiply("t", "2"));
}

На цьому етапі ми навчилися явно обробляти помилки за допомогою комбінацій і ранніх повернень. Хоча загалом ми хочемо уникати паніки, явна обробка всіх наших помилок є обтяжливою.

У наступному розділі ми представимо ? для випадків, коли нам просто потрібно unwrap, не спричиняючи можливу panic.