Option에서 Result 꺼내기
혼합된 에러 타입들을 처리하는 가장 기본적인 방법은 단순히 서로를 내포시키는 것입니다.
use std::num::ParseIntError;
fn double_first(vec: Vec<&str>) -> Option<Result<i32, ParseIntError>> {
vec.first().map(|first| {
first.parse::<i32>().map(|n| 2 * n)
})
}
fn main() {
let numbers = vec!["42", "93", "18"];
let empty = vec![];
let strings = vec!["두부", "93", "18"];
println!("두 배가 된 첫 번째 값은 {:?}입니다", double_first(numbers));
println!("두 배가 된 첫 번째 값은 {:?}입니다", double_first(empty));
// 에러 1: 입력 벡터가 비어 있습니다
println!("두 배가 된 첫 번째 값은 {:?}입니다", double_first(strings));
// 에러 2: 요소를 숫자로 파싱할 수 없습니다
}
에러가 발생하면 처리를 중단하고 싶지만(?와 같이), Option이 None일 때는 계속 진행하고 싶을 때가 있습니다. 이럴 때 Result와 Option을 서로 바꾸어 주는 transpose 함수가 유용합니다.
use std::num::ParseIntError;
fn double_first(vec: Vec<&str>) -> Result<Option<i32>, ParseIntError> {
let opt = vec.first().map(|first| {
first.parse::<i32>().map(|n| 2 * n)
});
opt.transpose()
}
fn main() {
let numbers = vec!["42", "93", "18"];
let empty = vec![];
let strings = vec!["두부", "93", "18"];
println!("두 배가 된 첫 번째 값은 {:?}입니다", double_first(numbers));
println!("두 배가 된 첫 번째 값은 {:?}입니다", double_first(empty));
println!("두 배가 된 첫 번째 값은 {:?}입니다", double_first(strings));
}