• lime!@feddit.nu
    link
    fedilink
    arrow-up
    5
    arrow-down
    1
    ·
    1 day ago

    skipped a few steps there i think.

    anyway, good question. led me to some cursed code.

    the ArrayObject in spidermonkey is an interface to either a TypedArrayObject or a SharedArrayObject. those both have an inner ArrayBuffer object, which is a view into ArrayBufferObjectMaybeShared, which contains a refcounted vector of uint8 pointers, regardless of the datatype. soooo all arrays in javascript are… strings?

    • thebestaquaman@lemmy.world
      link
      fedilink
      arrow-up
      1
      ·
      12 hours ago

      If I’m understanding you correctly, they’re basically doing the same thing as Python under the hood and using a heap-allocated array (vector) of pointers? If so, that should still be orders of magnitude faster than a linked list.

      If their implementation is actually a linked list, colour me shocked. My impression was that JavaScript is “decently fast”. I’ve never even considered writing high-performance code in it, but I’ve heard that the compiler can optimise extremely aggressively, and it’s used so widely that I couldn’t imagine that it had glaring performance issues like what I would expect to see if every array was actually a linked list under the hood.

      • lime!@feddit.nu
        link
        fedilink
        arrow-up
        1
        ·
        10 hours ago

        can’t a jit move things around enough that a linked list could be transformed into a memory-backed array if the access pattern requires it.

        • thebestaquaman@lemmy.world
          link
          fedilink
          arrow-up
          1
          ·
          8 hours ago

          Sure it can, as long as it retains behaviour according to whatever standard it needs to comply to. My point was rather that I would be very surprised if the actual implementation (at memory level) was a linked list.

    • qprimed@lemmy.ml
      link
      fedilink
      English
      arrow-up
      4
      ·
      1 day ago

      skipped a few steps there i think.

      thanks for the considered reply. didn’t mean to jump all the way down to electrons and sound so flippant.

      my claim is that JavaScript arrays are arrays because the spec defines their behavior as such. the implementation details are absolutely interesting from a performance perspective and I was genuinely curious how an internally linked list implementation would actually work, real-world. regardless… almost every interaction I have ever had with a JS programmer has ended in “its strings all the way down”… so… I mean… yes-ish?

      loved your poking of the hornets nest in this thread :-)

      • lime!@feddit.nu
        link
        fedilink
        arrow-up
        3
        ·
        1 day ago

        i was thinking between the linked list and the transistors :)

        also, i mean… what you might call an array i might call a vector. js arrays allow elements of different types, so they are by definition not arrays in the traditional sense. them being chars internally does make sense in a gross way.