Don’t say anyway, say anyhow

      • magic_lobster_party@fedia.io
        link
        fedilink
        arrow-up
        22
        ·
        3 months ago

        Unwrap means it forces to evaluate the result as an ”ok value”. If it’s an ”error value”, it will crash. It’s a bad practice to rely on it, as it’s one of the most common ways a Rust programs can crash.

        Rust offers many options to handle errors that don’t risk crashing. For example, unwrap_or_default, which means ”if it’s an error value, use the default value for this type, such as 0 for integers”

        • Korne127@lemmy.world
          link
          fedilink
          arrow-up
          11
          ·
          3 months ago

          I mean using unwrap is not bad practice if the value is guaranteed to not be none, which can happen frequently in some applications.

            • Korne127@lemmy.world
              link
              fedilink
              arrow-up
              1
              ·
              3 months ago

              A very typical use-case would be getting something from a HashMap (or a Vector) and calling unwrap because you know it must exist (as you got a reference to the index or object that must be valid in the HashMap or Vector).
              Or if you call a function that returns Option<…> depending on the current state and you know that it must return Some(…) in the current situation.

        • sirdorius@programming.dev
          link
          fedilink
          arrow-up
          3
          ·
          edit-2
          3 months ago

          Unwrap is good for prototyping and trying out stuff fast, but it generally shouldn’t make it past a code review onto main, unless you’re very sure

          • dejected_warp_core@lemmy.world
            link
            fedilink
            arrow-up
            2
            ·
            3 months ago

            Exactly.

            Personally, I call it “python mode” since you’re staying on the “happy path” and let the program just crash out if those expectations aren’t met.

      • Ediacarium@feddit.org
        link
        fedilink
        arrow-up
        9
        ·
        3 months ago

        Languages like Java or C++ have Exceptions, which are errors, that are not explicitly mentioned in the function signature. Meaning, you might need to handle an exception you didn’t even know existed. And if you don’t, your program will just crash when these exceptions occur.

        In Rust all errors are explicitly mentioned and part of the return type. Because of this Rust has a lot of ways to quickly handle an error. One of those ways is “Trust me, bro” (or .unwrap()), which converts the combined error/success return type into just a success type, causing the program to crash if it actually was an error, restoring the more unsafe behavior of other languages.

        • Dave.@aussie.zone
          link
          fedilink
          arrow-up
          5
          ·
          3 months ago

          causing the program to crash if it actually was an error, restoring the more unsafe behavior of other languages.

          Wellllll it’s more of an abrupt exit rather than a crash, which is still better than eg. silently accessing beyond the end of an array, or ending up with a pointer to nowhere when you thought you had a sane memory reference.

          • arendjr@programming.dev
            link
            fedilink
            arrow-up
            2
            ·
            3 months ago

            “An abrupt exit”, more commonly known as a “crash”.

            If you’re going to argue that an exit through panic!() is not a crash, I will argue that your definition of a crash is just an abrupt exit initiated by the OS. In other words, there’s no meaningful distinction as the result is the same.

            • qaz@lemmy.worldOP
              link
              fedilink
              English
              arrow-up
              2
              ·
              edit-2
              3 months ago

              I don’t think that’s a valid comparison. The behavior does differ when it comes to cleanly releasing resources. Rust’s panic performs the drop actions for the current values on the stack, a SIGILL or SIGSEGV crash doesn’t.

              #[derive(Debug)]
              struct MyStruct {}
              
              impl Drop for MyStruct {
              	fn drop(&mut self) {
              		println!("{:?}", "imagine cleanup here"); // this is called
              	}
              }
              
              fn main() {
              	let a = MyStruct {};
              	panic!("panic!");
                      println!("{a:?}");
              }
              

              Try it yourself

              • arendjr@programming.dev
                link
                fedilink
                arrow-up
                3
                ·
                3 months ago

                That’s fair, although technically you could catch SIGSEGV and release resources that way too.

                Also, given that resources will be reclaimed by the OS regardless of which kind of crash we’re talking about, the effective difference is usually (but not always) negligible.

                Either way, no user would consider a panic!() to be not a crash because destructors ran. And most developers don’t either.

            • Dave.@aussie.zone
              link
              fedilink
              arrow-up
              1
              ·
              3 months ago

              I was talking more about unwrap causing a panic rather than calling the actual panic macro directly. Rust forces the programmer to deal with bad or ambiguous results, and what that is exactly is entirely decided by the function you are calling. If a function decides to return None when (system timer mod 2 == 0), then you’d better check for None in your code.

              Once you get to a point where we are doing the actual panic, well, that is starting to just be semantics.

        • thevoidzero@lemmy.world
          link
          fedilink
          arrow-up
          1
          ·
          3 months ago

          Crashing through unwrap is not necessarily restoring unsafe behavior of other languages though. I’d consider this wayyyy better than silently continuing with invalid value until the program tries something that doesn’t make sense/is overreaching and it crashes.