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 14:40] root |
devlogs:7_5_2022 [2023/10/19 15:25] (current) |
||
---|---|---|---|
Line 164: | Line 164: | ||
println!(" | println!(" | ||
+ | //Copied from the rust book | ||
</ | </ | ||
Line 203: | Line 204: | ||
} // Here, some_integer goes out of scope. Nothing special happens. | } // 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 | ||