• Trantarius@programming.dev
    link
    fedilink
    English
    arrow-up
    5
    arrow-down
    40
    ·
    9 months ago

    Y2K specifically makes no sense though. Any reasonable way of storing a year would use a binary integer of some length (especially when you want to use as little memory as possible). The same goes for manipulations; they are faster, more memory efficient, and easier to implement in binary. With an 8-bit signed integer counting from 1900, the concerning overflows would occur in 2028, not 2000. A base 10 representation would require at least 8 bits to store a two digit number anyway. There is no advantage to a base 10 representation, and there never has been. For Y2K to have been anything more significant than a text formatting issue, a whole lot of programmers would have had to go out of their way to be really, really bad at their jobs. Also, usage of dates beyond 2000 would have increased gradually for decades leading up to it, so the idea it would be any sort of sudden catastrophe is absurd.

    • The Octonaut
      link
      fedilink
      English
      arrow-up
      49
      arrow-down
      1
      ·
      9 months ago

      The issue wasn’t using the dates. The issue was the computer believing it was now on those dates.

      I’m going to assume you aren’t old enough to remember, but the “only two digits to represent the year” issue predates computers. Lots of paper forms just gave two digits. And a lot of early computer work was just digitising paper forms.

    • GoodEye8@lemm.ee
      link
      fedilink
      English
      arrow-up
      38
      arrow-down
      2
      ·
      9 months ago

      You’re thinking of the problem with modern solutions in mind. Y2K originates from punch cards where everything was stored in characters. To save space only the last 2 digits of the year because back then you didn’t need to store the 19 of year 19xx. The technique of storing data stayed the same for a long time despite technology advancing beyond punch cards. The assumption that it’s always 19xx caused the Y2K bug because once it overflows to 00 the system doesn’t know if it’s 1900 or 2000.

    • frezik@midwest.social
      link
      fedilink
      English
      arrow-up
      31
      ·
      9 months ago

      With an 8-bit signed integer counting from 1900…

      Some of the computers in question predate standardizing on 8 bits to the byte. You’ve got a whole post here of bad assumptions about how things worked.

    • SkippingRelax@lemmy.world
      link
      fedilink
      English
      arrow-up
      23
      arrow-down
      1
      ·
      9 months ago

      a whole lot of programmers would have had to go out of their way to be really, really bad at their jobs.

      You don’t spend much time around them, do you?

    • breakingcups@lemmy.world
      link
      fedilink
      English
      arrow-up
      19
      arrow-down
      1
      ·
      9 months ago

      You do realize that “counting from 1900” meant storing only the last two digits and just hardcoding the programs to print"19" in front of it in those days? At best, an overflow would lead to 19100, 1910 or 1900, depending on the print routines.

    • Matombo@feddit.de
      link
      fedilink
      English
      arrow-up
      13
      ·
      9 months ago

      Oh boy you heavily underestimate the amount and level of bad decision in legacy protokoll. Read up in the toppic. the Date was for a loong time stored as 6 decimal numbers.

    • thomasw@sh.itjust.works
      link
      fedilink
      English
      arrow-up
      12
      ·
      9 months ago

      And then there is PIC 99 in Cobol. In modern languages, it makes no sense, but there is still a lot of really old code around and not everything is twos complement, especially if you do not need the efficiency in memory and calculations.