• Ephera@lemmy.ml
    link
    fedilink
    arrow-up
    3
    ·
    2 months ago

    Honestly, it’s still ridiculous to me how slow Python, Java, JS, Ruby etc. continue to feel, even after decades of hardware optimizations. You’d think their slowness would stop being relevant at some point, because processors and whatnot have become magnitudes faster, but you can still feel it quite well, when something was implemented in one of those.

    • Urist@lemmy.ml
      link
      fedilink
      English
      arrow-up
      2
      ·
      2 months ago

      Many of these have C-bindings for their libraries, which means that slowness is caused by bad code (such as making a for loop with a C-call for each iteration instead of once for the whole loop).

      I am no coder, but it is my experience that bad code can be slow regardless of language used.

      • Ephera@lemmy.ml
        link
        fedilink
        arrow-up
        2
        ·
        edit-2
        2 months ago

        Bad code can certainly be part of it. The average skill level of those coding C/C++/Rust tends to be higher. And modern programs typically use hundreds of libraries, so even if your own code is immaculate, not all of your dependencies will be.

        But there’s other reasons, too:

        • Python, Java etc. execute their compiler/interpreter while the program is running.
        • CLIs are magnitudes slower, because these languages require a runtime to be launched before executing the CLI logic.
        • GUIs and simulations stutter around, because these languages use garbage collection for memory management.
        • And then just death by a thousand paper cuts. For example, when iterating over text, you can’t tell it to just give you a view/pointer into the existing memory of the text. Instead, it copies each snippet of text you want to process into new memory.
          And when working with multiple threads in Java, it is considered best practice to always clone memory of basically anything you touch. Like, that’s good code and its performance will be mediocre. Also, you better don’t think about using multiple threads in Python+JS. For those two, even parallelism was an afterthought.

        Well, and then all of the above feeds back into all the libraries not being performant. There’s no chance to use the languages for performance-critical stuff, so no one bothers optimizing the libraries.

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

          Java is still significantly faster and more efficient than Python tho - because it has ahead-of-time optimizations and is not executing plain text.

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

            Idk numpy go brrrrrrrrrr. I think it’s more just the right tool for the right job. Most languages have areas they excel at, and areas where they’re weaker, siloing yourself into one and thinking it’s faster for every implementation seems short sighted.

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

              At it’s heart, numpy is C tho. That’s exactly what I’m talking about. Python is amazing glue code. It makes this fast code more useful by wrapping it in simple® scripts and classes.

        • TimeSquirrel@kbin.melroy.org
          link
          fedilink
          arrow-up
          2
          ·
          2 months ago

          For example, when iterating over text, you can’t tell it to just give you a view/pointer into the existing memory of the text. Instead, it copies each snippet of text you want to process into new memory.

          As someone used to embedded programming, this sounds horrific.

          • Ephera@lemmy.ml
            link
            fedilink
            arrow-up
            1
            ·
            2 months ago

            Yep. I used to code a lot in JVM languages, then started learning Rust. My initial reaction was “Why the hell does Rust have two string types?”.
            Then I learned that it’s for representing actual memory vs. view and what that meant. Since then I’m thinking “Why the hell do JVM languages not have two string types?”.

            • calcopiritus@lemmy.world
              link
              fedilink
              arrow-up
              1
              ·
              2 months ago

              I’m not a java programmer, but I think the equivalent to str would be char[]. However the ergonomics of rust for str isn’t there for char[], so java devs probably use String everywhere.

      • aluminium@lemmy.world
        link
        fedilink
        arrow-up
        1
        ·
        2 months ago

        At least with Java, its the over(ab)use of Reflections and stuff like dependency injection that slows things down to a crawl.

    • GissaMittJobb@lemmy.ml
      link
      fedilink
      arrow-up
      2
      ·
      2 months ago

      There are a few reasons for this, some of the most important being:

      • The languages were not designed with speed primarily in mind and as such made some design decisions that fundamentally cannot be optimized around
      • Authors of programs in these languages prioritize things other than performance when writing the programs.

      Speed is not just about processors becoming faster - this is a large part of why DSA is important to learn as a programmer.

    • Possibly linux@lemmy.zip
      link
      fedilink
      English
      arrow-up
      1
      ·
      edit-2
      2 months ago

      “Slow”

      They aren’t as fast as a native language but they aren’t all that slow if you aren’t trying to use them for performance sensitive applications. Modern machines run all those very quickly as CPUs are crazy fast.

      Also it seems weird to put Java/OpenJDK in the list as it is in its own category from my experience

      • Ephera@lemmy.ml
        link
        fedilink
        arrow-up
        1
        ·
        2 months ago

        Java is certainly the fastest of the bunch, but I still find it rather noticeable how long the startup of applications takes and how it always feels a bit laggy when used for graphical stuff.

        Certainly possible to ignore that on a rational level, but that’s why I’m talking about how it feels.
        I’m guessing, this has to do with just the basic UX principle of giving the user feedback. If I click a button, I want feedback that my click was accepted and when the triggered action completed. The sooner those happen, the more confident I feel about my input and the better everything feels.

        • Possibly linux@lemmy.zip
          link
          fedilink
          English
          arrow-up
          1
          ·
          2 months ago

          I’ve never experienced that. Also Android is OpenJDK based and the applications in Android work well and the system is well optimized

  • Eskuero@lemmy.fromshado.ws
    link
    fedilink
    arrow-up
    3
    ·
    2 months ago

    As someone who only codes solutions for himself I don’t relate. All the extra time I would spend writting a C solution it would never attone the runtime loses of doing it in maybe python.

    • adhocfungus@midwest.social
      link
      fedilink
      arrow-up
      1
      ·
      2 months ago

      I used to write extensively with C++, but it has been a long time since speed mattered that much to one of my applications. I still marvel at the cache-level optimizations some people come up with, but I’m in the same mindset as you now.

      My workload split of Data Movement vs Data Transformation is like 95:5 these days, which means almost all the optimizations I do are changing batch/cache/page/filter settings. I can do that in any language with http bindings, so I choose those that are faster to write.

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

    Damn, that’s a fast ass-cheetah!

    What with passenger planes like the one depicted typically going 575-600 mph and the bar only 3 times as long, that dude is sprinting at upto 200mph!

    (Link is to classic xkcd comic, not furry porn)

    • VonReposti@feddit.dk
      link
      fedilink
      arrow-up
      2
      ·
      2 months ago

      Link is to classic xkcd comic, not furry porn

      Damn, you got my hopes up for a second there.

    • FuglyDuck@lemmy.world
      link
      fedilink
      English
      arrow-up
      1
      ·
      edit-2
      2 months ago

      (Link is to classic xkcd comic, not furry porn)

      I am both disappointed and pleased.

  • h0bbl3s@lemmy.world
    link
    fedilink
    arrow-up
    1
    ·
    2 months ago

    I used c++ in college, and I think it’s useful to know c because so much relies on it. That said if I’m going to do something that needs performance I’ll look to go first, then rust if go isn’t a good fit, but that’s mostly because I know go better. Both are excellent languages.

    If I just need something functional quick and easily I’ll turn to Python. If I need a net service quick node.js is great.

    • Opisek@lemmy.world
      link
      fedilink
      arrow-up
      1
      ·
      2 months ago

      I was a huge C++ fan back when I was doing a bunch of competitive programming. If I need a performant project nowadays, I look to golang first. It gives me the speed of a compiled language with the usability of high-level language. I still solve the occasional Advent of Code in C++, though :)