summaryrefslogtreecommitdiff
path: root/solutions/09_strings/strings4.rs
diff options
context:
space:
mode:
authormo8it <mo8it@proton.me>2024-07-05 13:39:50 +0200
committermo8it <mo8it@proton.me>2024-07-05 13:39:50 +0200
commit7123c7ae3a9605fbe962e4ef0a0f1424cd16fef8 (patch)
treec67f7e62bb9a179ae4fdbab492501cb6847e64c7 /solutions/09_strings/strings4.rs
parent77b687d501771c24bd83294d97b8e6f9ffa92d6b (diff)
parent4d9c346a173bb722b929f3ea3c00f84954483e24 (diff)
Merge remote-tracking branch 'upstream/main' into fix-enum-variant-inconsistency
Diffstat (limited to 'solutions/09_strings/strings4.rs')
-rw-r--r--solutions/09_strings/strings4.rs38
1 files changed, 38 insertions, 0 deletions
diff --git a/solutions/09_strings/strings4.rs b/solutions/09_strings/strings4.rs
new file mode 100644
index 0000000..9dc6917
--- /dev/null
+++ b/solutions/09_strings/strings4.rs
@@ -0,0 +1,38 @@
+fn string_slice(arg: &str) {
+ println!("{arg}");
+}
+fn string(arg: String) {
+ println!("{arg}");
+}
+
+fn main() {
+ string_slice("blue");
+
+ string("red".to_string());
+
+ string(String::from("hi"));
+
+ string("rust is fun!".to_owned());
+
+ // Here, both answers work.
+ // `.into()` converts a type into an expected type.
+ // If it is called where `String` is expected, it will convert `&str` to `String`.
+ // But if is called where `&str` is expected, then `&str` is kept `&str` since no
+ // conversion is needed.
+ string("nice weather".into());
+ string_slice("nice weather".into());
+ // ^^^^^^^ the compiler recommends removing the `.into()`
+ // call because it is a useless conversion.
+
+ string(format!("Interpolation {}", "Station"));
+
+ // WARNING: This is byte indexing, not character indexing.
+ // Character indexing can be done using `s.chars().nth(INDEX)`.
+ string_slice(&String::from("abc")[0..1]);
+
+ string_slice(" hello there ".trim());
+
+ string("Happy Monday!".replace("Mon", "Tues"));
+
+ string("mY sHiFt KeY iS sTiCkY".to_lowercase());
+}