“Rust’s compiler prevents common bugs” So does skill. No offense to you, but, this trope is getting so tiresome. If you like the language then go ahead and use it. What is it with the rust crowd that they have to come acrosslike people trying to convert your religion at your front door?

  • JackbyDev@programming.dev
    link
    fedilink
    English
    arrow-up
    5
    ·
    9 hours ago

    I can sympathize with some people getting tired of “rewrite it in Rust”, especially when it’s suggested inappropriately. (Worst I saw was an issue opened on something, maybe a database, I don’t remember. Someone said they were a new programmer and wanted to help and only knew a little Rust and that if the project was rewritten in Rust they could help.) But… Rust’s compiler being able to do those things is actually super useful and amazing. This is like someone saying they don’t need static types because they know the language good enough to not misuse the dynamic types. This is like someone saying they don’t need C because they’re good at assembly.

    While it isn’t something as simple as Rust being strictly better than C/C++, it’s really silly to say that you being a good developer means you don’t need guardrails. Everybody makes mistakes all the time. You’re not perfect.

  • boaratio@lemmy.world
    link
    fedilink
    arrow-up
    3
    arrow-down
    1
    ·
    14 hours ago

    At my last job I worked in a code base written in C and it needed to be certified to MISRA level A, and even in a language with as many foot guns as C, it’s possible to write safe code. You just need to know what you’re doing. I know there are tons of Rust zealots out there claiming it’ll solve every last problem, but it turns out you just need to be careful.

  • hedge_lord@lemmy.world
    link
    fedilink
    English
    arrow-up
    38
    ·
    1 day ago

    Unlike you babies I have Personal Responsibility and I write all of my code directly in assembly the way reagan intended. I don’t need guard rails and I’ve never had any issues with it because my Personal Responsibility keeps me safe

  • CanadaPlus@lemmy.sdf.org
    link
    fedilink
    arrow-up
    27
    arrow-down
    2
    ·
    edit-2
    1 day ago

    I’d guess it’s Rust fan’s genuine belief that they have something revolutionary.

    “Rust’s compiler prevents common bugs” So does skill. No offense to you, but, this trope is getting so tiresome. If you like the language then go ahead and use it.

    If you’re that much of a galaxybrain, you should be writing everything directly in opcodes. In reality, nobody is, and we invented languages to help us perform an activity the human brain is very poorly suited to.

    This attitude also means that OP stares at their own obvious bugs on a screen all day and then decides they’re great, which is level of detachment from reality frightening to me.

    • LeFantome@programming.dev
      link
      fedilink
      arrow-up
      20
      ·
      edit-2
      1 day ago

      Sadly, it is a detachment from reality that is entirely normal, even typical. In all walks of life.

      What I still find surprising, even though normal, is how technical people can push actual facts and evidence right out of their world view.

      Sure, 70% of the bugs in C++ code bases are memory rated according to multiple sources. So let me aggressively and confidently berate this idiot that says the Rust compiler is doing something useful.

      You do not have to use either language to see how idiotic this is. Even if you accept that this guy has “the skill” to make compiler help redundant, he has no point at all unless he thinks that “typical” C++ users have that same level of skill. And, provably and trivially researched—they do not. Being this wrong makes him, as self-evidenced, incompetent by definition.

      All he proves in the end is that he is angry (and I guess not a fan of Rust).

      “Angry and incompetent” is sadly a much more common trope than the ones he tires off.

      • squaresinger@lemmy.world
        link
        fedilink
        arrow-up
        8
        ·
        19 hours ago

        There’s some weird effects with language-specific bug rates.

        In old Java, most uncaught exceptions are NullpointerExceptions, because most other exceptions used to be checked. Can’t not catch a checked exception.

        So they made Kotlin, where NullpointerExceptions are the only type of checked exceptions. Now there are no unhandled NPEs anymore but now you get tons of other exceptions.

      • CanadaPlus@lemmy.sdf.org
        link
        fedilink
        arrow-up
        2
        ·
        22 hours ago

        Oh yes, it’s so very human nature. But damn.

        Most coders get the message at least a bit, I think. Other engineers have a reputation for massive egotism, software engineers don’t really.

        • qaz@lemmy.world
          link
          fedilink
          English
          arrow-up
          1
          ·
          15 hours ago

          Other engineers have a reputation for massive egotism, software engineers don’t really.

          That’s a joke right?

          • CanadaPlus@lemmy.sdf.org
            link
            fedilink
            arrow-up
            1
            ·
            edit-2
            8 hours ago

            Well, it’s possible I’m missing something, or that there’s a different reputation actually in the industry, since I’m an amateur. The first stereotypes I think of are unkempt, caffeine-dependent and socially inept.

            When I’ve seen people asking for help online, traditional engineers seem much more likely to flex their credentials and then not actually answer. Although there’s definitely software examples as well.

  • masterspace@lemmy.ca
    link
    fedilink
    English
    arrow-up
    41
    arrow-down
    2
    ·
    edit-2
    2 days ago

    Skill issue takes are dumb as fuck. It’s just republican personal responsibility takes using different language.

    Intelligent people focus on producing systemically better outcomes.

  • Scoopta@programming.dev
    link
    fedilink
    arrow-up
    27
    arrow-down
    1
    ·
    edit-2
    2 days ago

    While I do totally see the advantages of rust and agree skill is not a solution given people make mistakes…I do agree a lot of the very vocal rust advocates do act almost religious and it is an annoying turn off.

    • Valmond@lemmy.world
      link
      fedilink
      arrow-up
      19
      arrow-down
      1
      ·
      2 days ago

      We had the Java guys in year 2000, at least Rust seems to be a decent language.

      • LeFantome@programming.dev
        link
        fedilink
        arrow-up
        6
        ·
        1 day ago

        Java was created so that teams of intermediate skill programmers could maintain large, long-lived code bases. And it did its job incredibly well.

        If that is not your use case (or you do not want to admit that you are such a programmer), it may not be your favourite language.

        I always like C# far better. It may be my favourite language overall. It has a bit more headroom and was designed somebody far more skilled. But it was designed to compete directly with Java. So, you know who it was built for.

      • zarkanian@sh.itjust.works
        link
        fedilink
        arrow-up
        2
        arrow-down
        1
        ·
        1 day ago

        I’ve never run into a Java evangelist. Every opinion I’ve ever heard about Java is something like “Yeah, this sucks”. I always thought that people put up with it because it’s write-once, run-anywhere, but so is, y’know, Python.

        • ZILtoid1991@lemmy.world
          link
          fedilink
          arrow-up
          2
          ·
          16 hours ago

          Early on, Java was advertized as the next great thing, ending headaches from system development, porting, and “promoting good programming practices through OOP”.

          Then people increasingly got tired of OOP and the speed penalty of both that paradigm and the JVM, not to mention more and more education institutes started to claim Java was too hard for beginners, and that Python would be better.

          Now we have Rust evangelists promoting the language as the next great thing, ending headaches from memory safety issues, porting (if you target WASM and pack your app into a Chromium instance), and “promoting good programming practices through FP”.

          Time is truly a flat circle…

        • Valmond@lemmy.world
          link
          fedilink
          arrow-up
          1
          arrow-down
          1
          ·
          19 hours ago

          There was a saying back in the day, roughly: “java can run on all platforms like anal sex works on all genders”.

          Python is slow but fantastic when it comes to interoperability IMO and is just complex enough that you can get the job done. I just hope they’ll won’t complexify it into oblivion, it’s a really neat language. IMO.

    • daniskarma@lemmy.dbzer0.com
      link
      fedilink
      arrow-up
      7
      ·
      1 day ago

      Do you have time to talk about our lord Rust? Did you know it died for our bugs so we don’t have to debug them at run time?

  • mokus@lemmy.blahaj.zone
    link
    fedilink
    arrow-up
    44
    arrow-down
    1
    ·
    2 days ago

    “Should I use rust or c++” is the wrong question IMO. The right question is “do I want the code I run, written by thousands or millions of randos, to be written in rust or c++”.

  • Treczoks@lemmy.world
    link
    fedilink
    arrow-up
    2
    arrow-down
    14
    ·
    18 hours ago

    The “common bugs” that the Rust compiler prevents are those a good programmer should not make in the first place. It’s the bugs that even evade a seasoned programmer that poses the problems, and there, Rust won’t help either.

    Remember ADA? A programming language frankesteined by a committee to make programming safer? The programmers using it still produce bugs. And ADA is way more whips and chains than Rust.

    • douglasg14b@lemmy.world
      link
      fedilink
      arrow-up
      1
      ·
      edit-2
      3 hours ago

      This is the same kind of argument that you shouldn’t have to wear seat belts because just don’t crash, duh.

      Why do we have traffic lights?? Just don’t hit each other, duh.

      You shouldn’t need emergency shutoffs at gas stations, don’t have a fire stupid!

      Hand rails on stairs? C’mon, just don’t trip.

      Confirmarion dialog on deleting data? Well, just don’t click the wrong thing 🤦

      It’s beyond obtuse

      And completely missed the entire problem of human error. Which is one of the only constants we can always rely upon in every situation in every industry everywhere.

      Being ignorant of something this pervasive and uniform across all humanity is not an excuse.

    • beegnyoshi@lemmy.zip
      link
      fedilink
      arrow-up
      20
      ·
      edit-2
      17 hours ago

      It’s the bugs that even evade a seasoned programmer that poses the problems, and there, Rust won’t help either

      What do you mean these are not the ones that rust tries to fix? Even huge projects like the linux kernel get memory bugs. I don’t know anything about ADA and nor do I want to “evangelize rust” but what you’re saying sounds boggers.

      Obviously rust cannot prevent all bugs or even most of them. It can only prevent a small subset of bugs, but saying that that “small subset of bugs” wouldn’t happen to seasoned programmers is just wrong, especially when you have tons of programmers working on the same big project.

      I don’t mean to say that rust is always the correct choice, but that you’re waving off its greatest offering as bicycle training wheels (i.e. something no seasoned programmer would need)

      • Treczoks@lemmy.world
        link
        fedilink
        arrow-up
        2
        arrow-down
        12
        ·
        17 hours ago

        but what you’re saying sounds boggers.

        Believe me, it isn’t. I program about anything for forty+ years now. I probably have forgotten more programming languages than you can list, and if there are constants in programming, then a) while compilers get better at catching bugs, they never got over the basics, and b) a good programmer will alyways be better at preventing and catching bugs than a compiler.

        Once you have aquired a good mindset about disciplined programming, those buglets a compiler (or even code review systems) can find usually don’t happen. Be wary of those bugs that evade the seasoned programmer, though…

        For the mindset, it is good to read and understand things like the MISRA standard. Stuff like that prevents bugs.

        • NotANumber@lemmy.dbzer0.com
          link
          fedilink
          arrow-up
          8
          ·
          edit-2
          14 hours ago

          Man hackers would love you. Memory vulnerabilities are still one of if not the main cause of vulnerabilities in unsafe languages. Yes this even applies to large projects ran by experienced and skilled people like the Linux kernel. Stop thinking your the exception, because I guarantee you aren’t but even if you were you can’t read all of the code in the world in your lifetime. Nor can you write all the code in the world.

        • beegnyoshi@lemmy.zip
          link
          fedilink
          arrow-up
          7
          ·
          16 hours ago

          I probably have forgotten more programming languages than you can list, and if there are constants in programming, then a) while compilers get better at catching bugs, they never got over the basics, and b) a good programmer will alyways be better at preventing and catching bugs than a compiler.

          I agree with this

          Once you have aquired a good mindset about disciplined programming, those buglets a compiler (or even code review systems) can find usually don’t happen.

          I also agree with this.

          I would like to put a lot of emphasis in the usually. It doesn’t mean that they don’t happen, no human being makes no mistakes. Rust simply gives people a little more peace of mind knowing that unless they use unsafe they’re probably fine in terms of memory issues.


          As a side note, there was this once I was making an ecs engine in rust, and kept fighting the compiler on this issue. Specifically, the game engine bevy uses Query in the World to retrieve information about the game state, and I wanted to do the same. For instance, in the following function (or something similar, I honestly don’t remember all that well):

          fn getplayer(player: Query<Player>) {}
          

          Would get player from the world and assign it to player (more or less). However rust was adamant in not letting me do this. After some thinking I finally realized why

          fn getplayer(player: Query<Player>, player_too: Query<Player>) {}
          

          Would give two mutable references to the same Player in the same function, which can be very easily mishandled, and thus is not allowed in rust.

          I don’t know about the MISRA standard, but I don’t think that using it would have changed the way I coded my inherently flawed approach. This is a small example, one that didn’t even matter that much in the grand scheme of things and could be even hard to understand why it’s bad without knowing rust, but it is the one that came to mind. I think that if I had more experience I would he able to give you one that actually had security implications.

          I’m no seasoned programmer, however

  • smiletolerantly@awful.systems
    link
    fedilink
    arrow-up
    133
    arrow-down
    9
    ·
    2 days ago
    • if your skill is so great that you would never cause the kinds of bugs the rust compiler is designed to prevent, then it will never keep you from compiling, and therefore your complaint is unnecessary and you can happily use rust
    • if you do encounter these error messages, then you are apparently not skilled enough to not use rust, and should use rust

    In summary: use rust.

      • smiletolerantly@awful.systems
        link
        fedilink
        arrow-up
        8
        arrow-down
        1
        ·
        2 days ago

        Curious what you are talking about. Multi-threaded sharing of memory for example is also easy with rust, it just doesn’t let you wrote and read at the same time, and so on.

    • jatone@lemmy.dbzer0.com
      link
      fedilink
      English
      arrow-up
      41
      ·
      2 days ago

      it always astounds me how utterly arrogant people are about their own abilities. (myself included) but seriously who the fuck doesnt like having something that just prevents you from doing things that are obviously broken and not going to work?

    • F04118F@feddit.nl
      link
      fedilink
      arrow-up
      38
      arrow-down
      1
      ·
      2 days ago

      I don’t agree with /u/red-crayon-scribbles ’ approach to memory safety, but what you’re saying isn’t entirely true either.

      It is possible to manipulate memory in ways that do not conform to Rust’s lifecycle/ownership model. In theory, this can even be done correctly.

      The problem is that in practice, this leads to the following, many of which were committed by some of the most highly skilled C developers alive, including major kernel contributors:

      https://xeiaso.net/blog/series/no-way-to-prevent-this/

      • Midnitte@beehaw.org
        link
        fedilink
        English
        arrow-up
        22
        ·
        2 days ago

        …echoing statements expressed by hundreds of thousands of programmers who use the only language where 90% of the world’s memory safety vulnerabilities have occurred in the last 50 years, and whose projects are 20 times more likely to have security vulnerabilities.

        ooof.

    • Decq@lemmy.world
      link
      fedilink
      arrow-up
      20
      arrow-down
      4
      ·
      edit-2
      2 days ago

      This so true, every one complaining that the borrow checker is annoying isn’t apparently aware what they used to do was inherently flawed. Sure there a some, though rare, false positives. But they are easily mitigated. These people are exactly that what they themselves are complaining about, elitist.

      • smiletolerantly@awful.systems
        link
        fedilink
        arrow-up
        14
        ·
        2 days ago

        Yeah. Once you get used to the (verbose, but by no means unergonomic!) syntax, you’ll probably never be happy with another language again. Job-wise, I am currently mostly using Go, and while also a nice language, I miss the confidence and security I took for granted with rust.

        Not to mention just how goddamn expressive rust can be. Let bindings like if ok/err, else return? Assign from a match on Some(Ok(x))? Filter, map, and friends on any iterator? Oh my GOD the error handling with the question mark iterator? 100% confidence that if it compiles, no error, possible null value, or case is unhandled.

        And all this WHILE giving you the amazing security benefits!

        Ah, damn, caught me proselytizing again.

  • AllNewTypeFace@leminal.space
    link
    fedilink
    arrow-up
    53
    arrow-down
    2
    ·
    2 days ago

    The human mind has limited capacity for things to pay attention to. If your attention is occupied with tiptoeing around the loaded guns scattered all over the floor, sooner or later you’ll slip and trip over one.

    Of course, you’re a virtuoso programmer, so you can pirouette balletically around the floorguns as you deliver brilliantly efficient code. Which is great, until you have an off day, or you get bored of coding, run off to join the circus as a professional knife-juggler and your codebase is inherited by someone of more conventional aptitude.

    Programming languages offering to keep track of some of the things programmers need to be aware of has been a boon for maintainability of code and, yes, security. Like type systems: there’s a reason we no longer write assembly language, squeezing multiple things into the bits of a register, unless we’re doing party tricks like demo coding or trying to push very limited systems to their limits.

    • BatmanAoD@programming.dev
      link
      fedilink
      arrow-up
      26
      ·
      2 days ago

      … until you have an off day, or you get bored of coding, run off to join the circus as a professional knife-juggler and your codebase is inherited by someone of more conventional aptitude.

      Sometimes you even have to deal with having mere mortals on your team!

      • nickwitha_k (he/him)@lemmy.sdf.org
        link
        fedilink
        arrow-up
        5
        arrow-down
        1
        ·
        1 day ago

        It is a way to go but there are still cons there. Guaranteeing memory safety isn’t free. You have to pay for it somewhere, either at compilation time, like Rust, or during runtime like in Go. Both are solid approaches but GC will cause problems in cases where the extra runtime overhead is not acceptable.

  • ExLisper@lemmy.curiana.net
    link
    fedilink
    arrow-up
    13
    arrow-down
    1
    ·
    2 days ago

    The really annoying part is all the people saying that you shouldn’t like Rust because actually it’s not magically bug free. Yeah, no shit. No one who touched Rust claims it lets you write bug free code. People like Rust because it’s modern, fast, has great tooling, great documentation and really nice features like Traits and Algebraic data types. Memory and thread safety is just a bonus.

    • cbazero@programming.dev
      link
      fedilink
      arrow-up
      3
      arrow-down
      13
      ·
      2 days ago

      Ammm actually… ☝️🤓 most Rust evengalists claim that Rust prevents you from writing bugs

      • LeFantome@programming.dev
        link
        fedilink
        arrow-up
        6
        ·
        edit-2
        1 day ago

        Some bugs. I have never heard anybody remotely skilled in Rust claim that it prevents bugs in general.

        Python prevents many classes of bugs too (compared to C++). And any statically typed compiler will prevent some bugs that Python allows. Not too controversial I hope. Of course, unlike Rust, Python is unsuitable for many C++ use cases for other reasons.

        I do not use Rust and my self-image is not tied to C++. So I do not have to get upset when people explain the benefits of Rust.

        Rust is not perfect. That is why I do not use it. But it is not some elaborate lie either. It was designed to do certain things, and it does.

      • ryathal@sh.itjust.works
        link
        fedilink
        arrow-up
        5
        ·
        1 day ago

        Any type safe language will help you prevent a wide range of bugs that non safe languages need tons of tests to detect.

      • ExLisper@lemmy.curiana.net
        link
        fedilink
        arrow-up
        7
        ·
        2 days ago

        It’s hard to argue with that statement. Like, literally, I have no idea who rust evangelists are, where to look for them and how to find out what “most” of them think about anything.

        • banshee@lemmy.world
          link
          fedilink
          arrow-up
          1
          ·
          1 day ago

          Yep - I don’t really know who these evangelists are either. I have read about “fearless concurrency,” which seems pretty spot-on.

  • IrateAnteater@sh.itjust.works
    link
    fedilink
    arrow-up
    69
    arrow-down
    1
    ·
    2 days ago

    At this point, I’ve seen far more people being almost violently anti-rust than I’ve seen people being weirdly enthusiastic about rust. If Rust people are Jehovah’s Witnesses, then a lot of the anti-Rust people are ISIS.

    • wer2@lemmy.zip
      link
      fedilink
      arrow-up
      1
      ·
      22 hours ago

      Try suggesting people try out a garbage collected language and see how the crabs come to feast. :P

    • baguettefish@discuss.tchncs.de
      link
      fedilink
      English
      arrow-up
      23
      arrow-down
      1
      ·
      edit-2
      2 days ago

      i think one factor (though definitely not all) of the dislike is the politics of the project, which are fairly inclusive and kind. some people can’t stomach that. another factor might be that the mere existence of rust implies that a lot of people are not the 100x rockstar developer they might aspire to be. maybe it’s also just a simple change = bad. though i have seen people who dislike rust also gravitate towards zig, and that also has some big differences. maybe it’s a hate towards mozilla? when i talk to people who hate rust they don’t articulate themselves well, so i have to speculate and i get nowhere. one thing i do hear about rust a lot is that it’s ugly, but I don’t really get that. i can’t personally fathom disdaining to use a tool simply because of looks, and i also don’t personally think rust is ugly.

      • Log in | Sign up@lemmy.world
        link
        fedilink
        arrow-up
        18
        arrow-down
        1
        ·
        2 days ago

        I think a bunch of C programmers hate rust passionately because they always looked down their noses at principled languages for being slow.

        Now a principled language is beating them on both speed and safety and it’s as if the jocks lost a baseball game to the nerds who studied dynamics of solids and cut a series of little slots in their bats so that every time they hit the ball it went out of the park.

        So much hate for the clever win over the brute force.

        • PlexSheep@infosec.pub
          link
          fedilink
          arrow-up
          2
          ·
          15 hours ago

          Rust is a tiny bit slower in benchmarks with similar implementations, since it has a few more runtime checks, but the difference is minor.

          • Log in | Sign up@lemmy.world
            link
            fedilink
            arrow-up
            1
            ·
            4 hours ago

            All depends what your trade offs are. “Milliseconds of run time versus months of debugging.” I know one team that were died in the wool C programmers but their baby had one too many security issues and their CTO said they had to reimplement it all in rust. One of them resigned but the others spent ages on it. They hated the borrow checker with a passion, almost as much as they hated the CTO, but after a bit they admitted it had some benefits and in the end they have a love/hate relationship with it. They hate the process still, but they love the result. The Milliseconds vs months quote is from my friend on that team. He said one subsystem had a seriously massive speed boost because they turned off the logging they used to do to recover from some infrequent intermittent bug that simply doesn’t happen any more. They’re proud of what they did.

      • kurwa@lemmy.world
        link
        fedilink
        arrow-up
        5
        arrow-down
        1
        ·
        2 days ago

        Correct me if I’m wrong because I never used Zig before, but I believe people like it because of the transparency in what the code is doing, like there’s no hidden functionality. Where as Rust definitely does do that.

    • It’s like the people complaining about SJWs and cancel culture. Sure, some people are annoying and use these things to harass others, but the vast majority are just normal people who care about certain things. But people on the other side, when they can’t provide a good argument against them, start to vilify the people themselves. It’s similar to how right wingers cry about decorum when they’re more likely to vote for rapists.

      I must admit that I had given into this anti-SJW hate at some point in my late teens, but I luckily realized how I was acting like a little bitch, hating on people I don’t even know just because they’re passionate about equality. The funny thing was, I still believed in their causes, but was pretty much brainwashed into believing that they’re hurting the cause by being vocal. It’s weird how dumb we often are.

  • B-TR3E@feddit.org
    link
    fedilink
    arrow-up
    38
    ·
    2 days ago

    The problem with these followers of rust is that they’re heathens, disbelievers and worshippers of the devil. Just like all of you heretics. There is just one programming language for the true believer and it is FORTRAN. The pure and true FORTRAN, that is, which is punched into cards of virgin paper, not the heresy created by the blasphemy of 99.