Categories
Tags
algorithms APIT Arc arm assembly asynchronous base64 BitHacks Blogging box c clang-format client cmake compiler concat concurrency const_fn contravariant cos covariant cpp Customization cybersecurity DataStructure db debugging Demo deserialization discrete doc DP dtruss Dynamic Example FFI flat_map format FP fsanitize Functional functions futures Fuwari GATs gccrs generics gitignore glibc GUI hacking hashmap haskell heap interop invariant iterator join justfile kernel LaTeX leak LFU linux lto MachineLearning macOS Markdown math ML mmap nc OnceLock optimization OS panic parallels perf physics pin postgresql radare2 release reverse RPIT rust sanitizer science Science serialization server shift sin SmallProjects socket std strace String StringView strip strlen surrealdb SWAR swisstable synchronous tan toml traits triangulation UnsafeRust utf16 utf8 Video wsl x86_64 xilem zig
221 words
1 minutes
250104_string_impl_concat_default
link
Rust Code
#[derive(Debug)]
struct Young {
data: String,
}
impl Default for Young {
fn default() -> Self {
Self {
data: "my_default".to_string(),
}
}
}
impl Young {
fn new() -> Self {
Self {
data: String::new(),
}
}
// append string slice
fn input(&mut self, x: &str) {
self.data.push_str(x);
}
// push a single character
fn push_char(&mut self, c: char) {
self.data.push(c);
}
// concat using format!
fn concat(&mut self, x: &str) {
self.data = format!("{}{}", self.data, x);
}
// join multiple strings
fn join_with(&mut self, parts: &[&str], sep: &str) {
self.data = parts.join(sep);
}
}
fn main() {
let data = Young::new();
let mut data2 = Young {
data: "young".to_string(),
};
println!("Initial data: {data:?}");
println!("Initial data2: {data2:?}");
// push_str
data2.input(" testtest");
println!("After push_str: {data2:?}");
// push (single char)
data2.push_char('!');
println!("After push: {data2:?}");
// concat
data2.concat(" CONCAT");
println!("After concat: {data2:?}");
// join
let parts = ["Rust", "is", "fast"];
data2.join_with(&parts, " ");
println!("After join: {data2:?}");
// default
let default_test = Young::default();
println!("{default_test:?}");
}- result
Initial data: Young { data: "" }
Initial data2: Young { data: "young" }
After push_str: Young { data: "young testtest" }
After push: Young { data: "young testtest!" }
After concat: Young { data: "young testtest! CONCAT" }
After join: Young { data: "Rust is fast" }
Young { data: "my_default" }250104_string_impl_concat_default
https://younghakim7.github.io/blog/posts/250104_string_impl_concat_default/