This shows you the differences between two versions of the page.
Both sides previous revision Previous revision Next revision | Previous revision | ||
devlogs:7_5_2022 [2022/05/08 00:08] root |
devlogs:7_5_2022 [2023/10/19 15:25] (current) |
||
---|---|---|---|
Line 164: | Line 164: | ||
println!(" | println!(" | ||
+ | //Copied from the rust book | ||
</ | </ | ||
Line 171: | Line 172: | ||
<wrap lo> things that can be copied : u32, | <wrap lo> things that can be copied : u32, | ||
+ | |||
+ | an (i32,i32) can be copied but a (i32, | ||
+ | |||
+ | == Ownership and Functions == | ||
+ | |||
+ | its simple | ||
+ | <code rust> | ||
+ | |||
+ | fn main() { | ||
+ | let s = String:: | ||
+ | |||
+ | takes_ownership(s); | ||
+ | // ... and so is no longer valid here | ||
+ | |||
+ | let x = 5; // x comes into scope | ||
+ | |||
+ | makes_copy(x); | ||
+ | // but i32 is Copy, so it's okay to still | ||
+ | // use x afterward | ||
+ | |||
+ | } // Here, x goes out of scope, then s. But because s's value was moved, nothing | ||
+ | // special happens. | ||
+ | |||
+ | fn takes_ownership(some_string: | ||
+ | println!(" | ||
+ | } // Here, some_string goes out of scope and `drop` is called. The backing | ||
+ | // memory is freed. | ||
+ | |||
+ | fn makes_copy(some_integer: | ||
+ | println!(" | ||
+ | } // Here, some_integer goes out of scope. Nothing special happens. | ||
+ | |||
+ | //Copied from the rust book | ||
+ | </ | ||
+ | |||
+ | Things that derive copy, get copied into a function. and droppable types get moved. | ||
+ | Returning stuff follows a similar rule. | ||
+ | |||
+ | <code rust> | ||
+ | fn main() { | ||
+ | let s1 = gives_ownership(); | ||
+ | // value into s1 | ||
+ | |||
+ | let s2 = String:: | ||
+ | |||
+ | let s3 = takes_and_gives_back(s2); | ||
+ | // takes_and_gives_back, | ||
+ | // moves its return value into s3 | ||
+ | } // Here, s3 goes out of scope and is dropped. s2 was moved, so nothing | ||
+ | // happens. s1 goes out of scope and is dropped. | ||
+ | |||
+ | fn gives_ownership() -> String { // gives_ownership will move its | ||
+ | // return value into the function | ||
+ | // that calls it | ||
+ | |||
+ | let some_string = String:: | ||
+ | |||
+ | some_string | ||
+ | // moves out to the calling | ||
+ | // function | ||
+ | } | ||
+ | |||
+ | // This function takes a String and returns one | ||
+ | fn takes_and_gives_back(a_string: | ||
+ | // scope | ||
+ | |||
+ | a_string | ||
+ | } | ||
+ | //Taken from the rust docs.. Again please read that. and not this... | ||
+ | </ | ||
+ | |||
+ | S1 gets ownership from the functions return. | ||
+ | |||
+ | S2 is moved into the function and then is returend back to s3 | ||
+ | |||