Решение на упр.02 задача 2 от Венислав Трендафилов

Обратно към всички решения

Към профила на Венислав Трендафилов

Резултати

  • 1 точка от тестове
  • 0 бонус точки
  • 1 точка общо
  • 1 успешни тест(а)
  • 0 неуспешни тест(а)

Код

fn print_str(s: &str) {
println!("Стрингово съдържание: {}", s);
}
fn append_exclamation(s: &mut String) {
s.push('!'); // добави '!' в края на низа
}
fn main() {
let mut s = String::from("Здравей");
print_str(&s);
append_exclamation(&mut s);
print_str(&s);
}
//Обясни защо използваме &str, а не &String във fn print_str(s: &str)
//Защото &str е за четене на низове без да се променят, а при print_str не искаме
//да променяме низа, а само да го прочетем. Освен това &str е по-общ тип от &String.
//Обясни защо използваме &mut String, а не &mut str във fn append_exclamation(s: &mut String)
//Защото искаме да добавим символ към низа, което изисква
//собственост, а не само върху срез(str). При &mut str може да се промени само съдържанието,
//но не и да се добавят нови символи.
//Какво би станало, ако в main направиш let r1 = &s; let r2 = &mut s;
//едновременно — ще компилира ли? Защо?
//Няма да компилира. Не може да имаме едновременно
//неизменяеми(&s) и изменяеми(&mut s) референции към една и съща стойност.

Лог от изпълнението

Updating crates.io index
     Locking 17 packages to latest compatible versions
   Compiling proc-macro2 v1.0.103
   Compiling quote v1.0.41
   Compiling unicode-ident v1.0.20
   Compiling futures-core v0.3.31
   Compiling futures-sink v0.3.31
   Compiling futures-channel v0.3.31
   Compiling futures-task v0.3.31
   Compiling syn v2.0.108
   Compiling pin-project-lite v0.2.16
   Compiling futures-io v0.3.31
   Compiling slab v0.4.11
   Compiling pin-utils v0.1.0
   Compiling memchr v2.7.6
   Compiling solution v0.1.0 (/tmp/d20251024-1757769-ymksih/solution)
warning: function `print_str` is never used
 --> src/lib.rs:1:4
  |
1 | fn print_str(s: &str) {
  |    ^^^^^^^^^
  |
  = note: `#[warn(dead_code)]` on by default

warning: function `append_exclamation` is never used
 --> src/lib.rs:5:4
  |
5 | fn append_exclamation(s: &mut String) {
  |    ^^^^^^^^^^^^^^^^^^

warning: function `main` is never used
 --> src/lib.rs:9:4
  |
9 | fn main() {
  |    ^^^^

warning: `solution` (lib) generated 3 warnings
   Compiling futures-macro v0.3.31
   Compiling futures-util v0.3.31
   Compiling futures-executor v0.3.31
   Compiling futures v0.3.31
warning: function `main` is never used
 --> tests/../src/lib.rs:9:4
  |
9 | fn main() {
  |    ^^^^
  |
  = note: `#[warn(dead_code)]` on by default

warning: `solution` (test "solution_test") generated 1 warning
    Finished `test` profile [unoptimized + debuginfo] target(s) in 8.19s
     Running tests/solution_test.rs (target/debug/deps/solution_test-8a95694fa7066c20)

running 1 test
test solution_test::test_basic ... ok

test result: ok. 1 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s

История (2 версии и 0 коментара)

Венислав качи първо решение на 21.10.2025 21:42 (преди около 2 месеца)

Венислав качи решение на 22.10.2025 23:45 (преди около 1 месеца)

fn print_str(s: &str) {
println!("Стрингово съдържание: {}", s);
}
fn append_exclamation(s: &mut String) {
s.push('!'); // добави '!' в края на низа
}
fn main() {
let mut s = String::from("Здравей");
print_str(&s);
append_exclamation(&mut s);
print_str(&s);
}
-#[test]
-fn test_basic() {
- let mut s = String::from("Здравей");
- print_str(&s);
- append_exclamation(&mut s);
- print_str(&s);
-
- assert_eq!(s, "Здравей!");
-}
//Обясни защо използваме &str, а не &String във fn print_str(s: &str)
//Защото &str е за четене на низове без да се променят, а при print_str не искаме
//да променяме низа, а само да го прочетем. Освен това &str е по-общ тип от &String.
//Обясни защо използваме &mut String, а не &mut str във fn append_exclamation(s: &mut String)
//Защото искаме да добавим символ към низа, което изисква
//собственост, а не само върху срез(str). При &mut str може да се промени само съдържанието,
//но не и да се добавят нови символи.
//Какво би станало, ако в main направиш let r1 = &s; let r2 = &mut s;
//едновременно — ще компилира ли? Защо?
//Няма да компилира. Не може да имаме едновременно
//неизменяеми(&s) и изменяеми(&mut s) референции към една и съща стойност.