println!("координаты точки: ({}, {})", point.x, point.y);
// Создадим новую точку используя синтаксис обновления структуры и нашу
// существующую точку
let bottom_right = Point { x: 5.2, ..point };
// `bottom_right.y` будет тем же самым, что и `point.y`, так как мы взяли
// это поле из `point`
println!("вторая точка: ({}, {})", bottom_right.x, bottom_right.y);
// Деструктурируем структуру при помощи `let`
let Point { x: top_edge, y: left_edge } = point;
let _rectangle = Rectangle {
// создание структуры также является выражением
top_left: Point { x: left_edge, y: top_edge },
bottom_right: bottom_right,
};
// Создадим unit-структуру
let _nil = Nil;
// Создадим кортежную структуру
let pair = Pair(1, 0.1);
// Доступ к полям кортежной структуры
println!("pair содержит {:?} и {:?}", pair.0, pair.1);
// Деструктурируем кортежную структуру
let Pair(integer, decimal) = pair;
println!("pair содержит {:?} и {:?}", integer, decimal);
}
הההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההה
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
1. Добавьте функцию rect_area, которая рассчитывает площадь прямоугольника (попробуйте использовать "деструктуризацию" (разбор на части)).
2. Добавьте функцию square, которая принимает в качестве аргументов Point и f32, а возвращает Rectangle, левый нижний угол которого соответствует Point, а ширина и высота соответствуют f32.
Атрибуты, времена жизни и деструктуризация
Ключевое слово enum позволяет создавать тип данных, который представляет собой один из нескольких возможных вариантов. Любой вариант, действительный как struct, также действителен как enum.
// Создаём `enum` для классификации web-событий. Обратите внимание
// как имена и информация о типе определяют вариант:
// `PageLoad != PageUnload` и `KeyPress(char) != Paste(String)`.
// Все они разные и независимые.
enum WebEvent {
// `enum` может быть как `unit-подобным`,
PageLoad,
PageUnload,
// так и кортежной структурой,
KeyPress(char),
Paste(String),
// или c-подобной структурой.
Click { x: i64, y: i64 },
}
// Функция, которая получает на вход `WebEvent` и ничего не возвращает.
fn inspect(event: WebEvent) {
match event {
WebEvent::PageLoad => println!("страница загружена"),
WebEvent::PageUnload => println!("страница выгружена"),
// Извлечём `c` из `enum`.
WebEvent::KeyPress(c) => println!("нажата '{}'.", c),