folkert@folkertdev.nl
folkert@tweedegolf.com
Let's put that into the types
&str | String |
---|---|
borrowed | owned |
immutable | mutable/growable |
struct &str {
ptr: *const u8,
length: usize,
}
struct String {
ptr: *const u8,
length: usize,
capacity: usize,
}
https://nee.lv/2021/02/28/How-I-cut-GTA-Online-loading-times-by-70/
pub fn from_utf8(v: &[u8]) -> Result<&str, Utf8Error>
// "0b00001100"
println!("0b{:08b}", 12);
use std::ffi::CString;
use std::os::raw::c_char;
extern "C" {
fn my_printer(s: *const c_char);
}
let c_to_print = CString::new("Hello, world!").unwrap()
unsafe {
my_printer(c_to_print.as_ptr());
}
use std::path::PathBuf;
let mut path = PathBuf::new();
path.push(r"C:\");
path.push("windows");
path.push("system32");
path.set_extension("dll");
assert_eq!(path, PathBuf::from(r"C:\windows\system32.dll"));
Rust uses types to encode invariants
Invariants are checked at the boundary
pub fn from_utf8(v: &[u8]) -> Result<&str, Utf8Error>
Gnarly details must be considered
But tries to wrap them up nicely
APIs for humans
pub struct Path {
inner: OsStr,
}
impl Path {
...
}
doc.rust-lang.org