cargo new project_name
: Initializes a new Rust project named project_name in the current directory.cargo build
: Build program without optimizations. Output is stored in ./target/debug.cargo build –release
: Build program with runtime optimizations. Output is stored in ./target/release.Length | Signed | Unsigned |
---|---|---|
8-bit | i8 | u8 |
16-bit | i16 | u16 |
32-bit | i32 | u32 |
64-bit | i64 | u64 |
128-bit | i128 | u128 |
arch | isize | usize |
f32
, f64
bool
char
let tup: (i32, f64, u8) = (500, 6.4, 1);
let (x, y, z) = tup; // x, y and z are now accessible as variables
or by using a period let x = tup.0;
let a = [1, 2, 3];
let a: [f64; 3] = [1.0, 2.0, 3.0];
let a = [0; 5];
: Creates an array of size 5 with all elements initialized to 0let first = a[0];
: Accessing elements of arrayfor element in a.iter() { … }
: Iterates over elements in arraylet foo = bar;
: Creates immutable variable foo
and assigns it value bar
.let mut foo = bar;
: Creates mutable variable foo
and assigns it value bar
.let foo: type = false;
: Creates immutable variable foo%
with explicit type definition.fn function_name() { … }
fn function_name(x: i32, y: char) { … }
: Parameterized functionfn function_name(x: i32) → i32 { … }
: Function with return value. Returned value is last evaluated expression of the function body.&var
: Passes var
as a reference. Allows a function to access a variable without the need to copy it to the function's stack.&mut var
: Passes var
as a mutable reference. Allows a function to access and alter the variable's value.