• dreugeworst@lemmy.ml
    link
    fedilink
    arrow-up
    9
    ·
    4 小时前

    I agree that experienced users can write code that leaks less than in C, leaving aside the bottomless pit of despair that is undefined behaviour. But the the language isn’t memory safe, it doesn’t even prevent you from returning a reference to a local or helpnwitg iterator invalidation. you don’t have to jump through any hoops to enable making that mistake.

    • Zacryon@feddit.org
      link
      fedilink
      arrow-up
      1
      ·
      23 分钟前

      If a language prevents you from doing stuff like that, this always comes at a cost, since it has to do the work for you, almost always. This is additional overhead you can get rid of in C++ and therefore gain a lot of performance. But that again comes with more responsibility on the developer’s side and you might need to implement appropriate checks yourself where needed.

      • qqq@lemmy.world
        link
        fedilink
        arrow-up
        1
        ·
        edit-2
        5 分钟前

        Rust prevents the things mentioned above in the compiler; there is no runtime cost for most of Rust’s safety measures. There is definitely a build time cost though.

        You can unsafe your way around anything, but that’s on the dev.