Читаем Rust на примерах полностью

val => println!("Получаем значение через разыменование: {:?}", val),

}

// Что если у нас нет ссылки? `reference` была с `&`,

// потому что правая часть была ссылкой. Но это не ссылка,

// потому что правая часть ею не является.

let _not_a_reference = 3;

// Rust предоставляет ключевое слово `ref` именно для этой цели.

// Оно изменяет присваивание так, что создаётся ссылка для элемента.

// Теперь ссылка присвоена.

let ref _is_a_reference = 3;

// Соответственно, для определения двух значений без ссылок,

// ссылки можно назначить с помощью `ref` и `ref mut`.

let value = 5;

let mut mut_value = 6;

// Используйте ключевое слово `ref` для создания ссылки.

match value {

ref r => println!("Получили ссылку на значение: {:?}", r),

}

// Используйте `ref mut` аналогичным образом.

match mut_value {

ref mut m => {

// Получаем ссылку. Её нужно разыменовать,

// прежде чем мы сможем что-то добавить.

*m += 10;

println!("Мы добавили 10. `mut_value`: {:?}", m);

},

}

}

הההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההה

XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

<p id="Структуры_1"><strong><a l:href="#Структуры_1">Структуры</a></strong></p>

Структуры могут быть деструктурированы следующим образом:

fn main() {

struct Foo { x: (u32, u32), y: u32 }

// деструктуризация члена структуры

let foo = Foo { x: (1, 2), y: 3 };

let Foo { x: (a, b), y } = foo;

println!("a = {}, b = {}, y = {} ", a, b, y);

// Вы можете деструктурировать структуру и переименовывать переменные,

// порядок при этом не важен

let Foo { y: i, x: j } = foo;

println!("i = {:?}, j = {:?}", i, j);

// а так же можно проигнорировать часть переменных:

let Foo { y, .. } = foo;

println!("y = {}", y);

// следующий код выдаст ошибку: в шаблоне нет упоминания поля `x`

// let Foo { y } = foo;

}

הההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההה

Перейти на страницу:

Похожие книги

Компьютерные сети. 6-е изд.
Компьютерные сети. 6-е изд.

Перед вами шестое издание самой авторитетной книги по современным сетевым технологиям, написанное признанным экспертом Эндрю Таненбаумом в соавторстве со специалистом компании Google Дэвидом Уэзероллом и профессором Чикагского университета Ником Фимстером. Первая версия этого классического труда появилась на свет в далеком 1980 году, и с тех пор каждое издание книги неизменно становилось бестселлером. В книге последовательно изложены основные концепции, определяющие современное состояние компьютерных сетей и тенденции их развития. Авторы подробно объясняют устройство и принципы работы аппаратного и программного обеспечения, рассматривают все аспекты и уровни организации сетей — от физического до прикладного. Изложение теоретических принципов дополняется яркими, показательными примерами функционирования интернета и компьютерных сетей различного типа. Большое внимание уделяется сетевой безопасности. Шестое издание полностью переработано с учетом изменений, произошедших в сфере сетевых технологий за последние годы, и, в частности, освещает такие технологии, как DOCSIS, 4G и 5G, беспроводные сети стандарта 802.11ax, 100-гигабитные сети Ethernet, интернет вещей, современные транспортные протоколы CUBIC TCP, QUIC и BBR, программно-конфигурируемые сети и многое другое.

Дэвид Уэзеролл , Ник Фимстер , Эндрю Таненбаум

Учебные пособия, самоучители