2022-07-15 12:01:32 +00:00
|
|
|
// lifetimes1.rs
|
|
|
|
//
|
|
|
|
// The Rust compiler needs to know how to check whether supplied references are
|
2023-05-29 17:39:08 +00:00
|
|
|
// valid, so that it can let the programmer know if a reference is at risk of
|
|
|
|
// going out of scope before it is used. Remember, references are borrows and do
|
|
|
|
// not own their own data. What if their owner goes out of scope?
|
2022-07-15 12:01:32 +00:00
|
|
|
//
|
2023-05-29 17:39:08 +00:00
|
|
|
// Execute `rustlings hint lifetimes1` or use the `hint` watch subcommand for a
|
|
|
|
// hint.
|
2022-07-15 12:01:32 +00:00
|
|
|
|
2024-02-02 00:24:03 +00:00
|
|
|
fn longest<'a>(x: &'a str, y: &'a str) -> &'a str {
|
2022-07-15 12:01:32 +00:00
|
|
|
if x.len() > y.len() {
|
|
|
|
x
|
|
|
|
} else {
|
|
|
|
y
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
fn main() {
|
|
|
|
let string1 = String::from("abcd");
|
|
|
|
let string2 = "xyz";
|
|
|
|
|
|
|
|
let result = longest(string1.as_str(), string2);
|
2022-08-28 13:10:29 +00:00
|
|
|
println!("The longest string is '{}'", result);
|
2022-07-15 12:01:32 +00:00
|
|
|
}
|