Rust: Difference between revisions

From bibbleWiki
Jump to navigation Jump to search
No edit summary
Line 22: Line 22:
  cargo build
  cargo build
  cargo run
  cargo run
= Fundamental Data Types =
== Primitive types ==
Cam declare with size of type
let a:u8 = 123; // unsigned int 8 bits number immutable
let a:i8 = 123; // signed int 8 bits number immutable
let mut a:u8 = 123; // unsigned int 8 bits number mutable
Or without e.g.
let mut c = 123456789 // 32-bit signed i32
println!("c = {}", c);
Now variable based on OS e.g.
let z:isize = 123 // signed 64 bit if on 64 bit OS
== Decimal ==
let e:f64 = 2.5 // double-precision, 8 bytes or 64-bits
== Char ==
let x:char = 'x' // Note 4 bytes unicode
== boolean ==
let g:bool = false; // Note 4 bytes unicode
= Operators =
Does not support -- and ++ but does support
a -= 2;
Remainder can be calculated using
a%3
Bitwise
let c = 1 | 2 // | OR
Shift
let two_to_10 = 1 << 10; // 1024
Logical of standard e.g.
let pi_less_4 = std::f64::consts::PI < 4.0; // true
= Scope and shadowing =
Curly braces keep scope
<syntaxhighlight lang="toml">
fn test()
{
  {
    let a = 5;
  }
  println!("Broken {a}");
}
</syntaxhighlight>
Shadowing is fine though
<syntaxhighlight lang="toml">
fn test()
{
  let a = 5;
  {
    let a = 10;
    println!("10 {a}");
  }
  println!("5 {a}");
}
</syntaxhighlight>
= Constants =
Standard const
<syntaxhighlight lang="rust">
const MEANING_OF_LIFE:u8 = 42;
</syntaxhighlight>
Static const
<syntaxhighlight lang="rust">
static Z:i32 = 123;
</syntaxhighlight>
= Stack and Heap =
Same a c++ i.e.
<syntaxhighlight lang="rust">
let y = Box::new(10);
println!("y = {}", *y);
</syntaxhighlight>

Revision as of 03:12, 22 June 2020

Sample program

fn main() {
    println!("Hello, world!");
}

Cargo

Sample file

[package]
name = "hello_world"
version = "0.0.1"
authors = [ "Iain Wiseman iwiseman@bibble.co.nz" ]

Sample commands

cargo new hello_world --bin
cargo build
cargo run

Fundamental Data Types

Primitive types

Cam declare with size of type

let a:u8 = 123; // unsigned int 8 bits number immutable
let a:i8 = 123; // signed int 8 bits number immutable
let mut a:u8 = 123; // unsigned int 8 bits number mutable

Or without e.g.

let mut c = 123456789 // 32-bit signed i32
println!("c = {}", c);

Now variable based on OS e.g.

let z:isize = 123 // signed 64 bit if on 64 bit OS

Decimal

let e:f64 = 2.5 // double-precision, 8 bytes or 64-bits

Char

let x:char = 'x' // Note 4 bytes unicode

boolean

let g:bool = false; // Note 4 bytes unicode

Operators

Does not support -- and ++ but does support

a -= 2;

Remainder can be calculated using

a%3

Bitwise

let c = 1 | 2 // | OR

Shift

let two_to_10 = 1 << 10; // 1024

Logical of standard e.g.

let pi_less_4 = std::f64::consts::PI < 4.0; // true

Scope and shadowing

Curly braces keep scope

 fn test()
 {
   {
     let a = 5; 
   }
   println!("Broken {a}");
 }

Shadowing is fine though

 fn test()
 {
   let a = 5; 
   {
     let a = 10; 
     println!("10 {a}");
   }
   println!("5 {a}");
 }

Constants

Standard const

 const MEANING_OF_LIFE:u8 = 42;

Static const

 static Z:i32 = 123;

Stack and Heap

Same a c++ i.e.

 let y = Box::new(10);
 println!("y = {}", *y);