Библиотека knigago >> Компьютеры: Языки и системы программирования >> Другие языки и системы программирования >> Rust на примерах


СЛУЧАЙНЫЙ КОММЕНТАРИЙ

# 1967, книга: Яблоки не падают никогда
автор: Лиана Мориарти

"Яблоки не падают никогда" Лианы Мориарти - захватывающая психологическая драма, которая погружает читателей в глубины семейных конфликтов. Это мастерски написанная история о трех братьях и сестрах, чьи отношения подвергаются испытанию, когда их мать исчезает без следа. Автор умело исследует сложную динамику между членами семьи, раскрывая их секреты и недомолвки. Каждому персонажу уделяется много внимания, а мотивы их поступков раскрываются постепенно, заставляя читателя сопереживать...

Коллектив авторов - Rust на примерах

Rust на примерах
Книга - Rust на примерах.   Коллектив авторов  - прочитать полностью в библиотеке КнигаГо
Название:
Rust на примерах
Коллектив авторов

Жанр:

Другие языки и системы программирования, Учебники и самоучители по компьютеру, Любительские переводы, Программирование: прочее

Изадано в серии:

неизвестно

Издательство:

неизвестно

Год издания:

ISBN:

неизвестно

Отзывы:

Комментировать

Рейтинг:

Поделись книгой с друзьями!

Помощь сайту: донат на оплату сервера

Краткое содержание книги "Rust на примерах"

https://doc.rust-lang.ru/stable/rust-by-example/
Rust - современный язык программирования, нацеленный на безопасность, скорость и параллелизм. Данные цели выполняются при условии безопасной работы с памятью без использования сборщика мусора.

Rust на примерах - это набор исполняемых примеров, которые иллюстрируют различные концепции языка Rust, а так же возможности его стандартной библиотеки. Для того, чтобы подчеркнуть ещё больше из этих примеров, не забудьте установить Rust на своём компьютере и проверить официальную документацию. Если вы ранее не сталкивались с языком программирования Rust, то советую вам для начала ознакомиться с русскоязычной книгой по Rust. Кроме этого можно посмотреть исходный код этого сайта или оригинала.

Читаем онлайн "Rust на примерах". [Страница - 5]

v);

}

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

XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

Задание

Попробуйте изменить программу так, чтобы индекс элемента так же выводился в консоль. Новый вывод должен выглядеть примерно вот так:

[0: 1, 1: 2, 2: 3]

Смотрите также:

for, ref, Result, struct, ?, и vec!

Форматирование

Мы видели, что форматирование задаётся макросом форматирования:

   • format!("{}", foo) -> "3735928559"

   • format!("0x{:X}", foo) ->"0xDEADBEEF"

   • format!("0o{:o}", foo) -> "0o33653337357"

Одна и та же переменная (foo) может быть отображена по разному в зависимости от используемого типа аргумента: X, o или неопределённый.

Функционал форматирования реализован благодаря типажу, и для каждого типа аргумента существует свой. Наиболее распространённый типаж для форматирования - Display, который работает без аргументов: {}, например.

use std::fmt::{self, Formatter, Display};

struct City {

name: &'static str,

// Широта

lat: f32,

// Долгота

lon: f32,

}

impl Display for City {

// `f` - это буфер, данный метод должен записать в него форматированную строку

fn fmt(&self, f: &mut Formatter) -> fmt::Result {

let lat_c = if self.lat >= 0.0 { 'N' } else { 'S' };

let lon_c = if self.lon >= 0.0 { 'E' } else { 'W' };

// `write!` похож на `format!`, только он запишет форматированную строку

// в буфер (первый аргумент функции)

write!(f, "{}: {:.3}°{} {:.3}°{}",

self.name, self.lat.abs(), lat_c, self.lon.abs(), lon_c)

}

}

#[derive(Debug)]

struct Color {

red: u8,

green: u8,

blue: u8,

}

fn main() {

for city in [

City { name: "Дублин", lat: 53.347778, lon: -6.259722 },

City { name: "Осло", lat: 59.95, lon: 10.75 },

City { name: "Ванкувер", lat: 49.25, lon: -123.1 },

].iter() {

println!("{}", *city);

}

for color in [

Color { red: 128, green: 255, blue: 90 },

Color { red: 0, green: 3, blue: 254 },

Color { red: 0, green: 0, blue: 0 },

].iter() {

// Поменяйте {:?} на {}, когда добавите реализацию

// типажа fmt::Display

println!("{:?}", *color)

}

}

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

XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

Вы можете посмотреть полный список типажей форматирования и их типы аргументов в документации к std::fmt.

Задание

Добавьте реализацию типажа fmt::Display для структуры Color, чтобы вывод отображался вот так:

RGB (128, 255, 90) 0x80FF5A

RGB (0, 3, 254) 0x0003FE

RGB (0, 0, 0) 0x000000

Пару подсказок, если вы не знаете, что делать:

   • Вам возможно потребуется перечислить каждый цвет несколько раз,

   • Вы можете добавить немного нулей с :02.

Смотрите также:

std::fmt

Примитивы

Rust предоставляет доступ к большому количеству примитивов:

Скалярные типы

   • знаковые целочисленные: i8, i16, i32, i64 и isize (размер указателя)

   • беззнаковые целочисленные: u8, u16, u32, u64 и usize (размер указателя)

   • вещественные: f32, f64

   • char скалярное значение Unicode, например: 'a', 'α' и '∞' (4 байта каждый)

   • bool: true или false

   • единичный тип (), значение которого так же ()

Несмотря на то, что значение единичного типа является кортежем, оно не считается составным типом, потому что не содержит нескольких значений.

Составные типы

   • массивы, например [1, 2, 3]

   • кортежи, например (1, true)

Переменные всегда должны быть аннотированы. Числам можно указать определённый тип с помощью суффикса, иначе будет присвоен тип по умолчанию. Целочисленные значения по умолчанию i32, а вещественные f64. Стоит заметить, что Rust также умеет выводить типы из контекста.

fn main() {

// Переменные могут быть аннотированы.

let logical: bool = true;

let a_float: f64 = 1.0; // Обычная аннотация

let an_integer = 5i32; // Суффиксная аннотация

// Этим переменным будет присвоен тип по умолчанию.

let default_float = 3.0; // `f64`

let default_integer = 7; // `i32`

// Тип также может быть выведен из контекста.

let mut inferred_type = 12; // Тип i64 выводится из другой строки

inferred_type = 4294967296i64;

--">

Оставить комментарий:


Ваш e-mail является приватным и не будет опубликован в комментарии.

Другие книги автора « Коллектив авторов»:

Книга Сказок.  Коллектив авторов
- Книга Сказок

Жанр: Сказки для детей

Год издания: 2016

Серия: Антология детской литературы

Япония в эпоху Хэйан (794-1185).  Коллектив авторов
- Япония в эпоху Хэйан (794-1185)

Жанр: Культурология и этнография

Год издания: 2009

Серия: Труды Института восточных культур и античности