this post was submitted on 11 Feb 2025
936 points (96.8% liked)

Programmer Humor

20499 readers
1419 users here now

Welcome to Programmer Humor!

This is a place where you can post jokes, memes, humor, etc. related to programming!

For sharing awful code theres also Programming Horror.

Rules

founded 2 years ago
MODERATORS
 
you are viewing a single comment's thread
view the rest of the comments
[–] [email protected] 5 points 3 days ago (15 children)

Arrays not starting at 1 bother me. I think the entrenched 0-based index is more important than any major push to use 1 instead, but if I could go back in time and change it I would.

[–] [email protected] 14 points 3 days ago (3 children)

It really doesn't make sense to start at 1 as the value is really the distance from the start and would screw up other parts of indexing and counters.

[–] [email protected] 8 points 3 days ago (2 children)

It would screw up existing code but doing [array.length() -1] is pretty stupid.

[–] [email protected] 3 points 2 days ago

A lot of languages have a .last() or negative indexer ([-1]) to get the last item though.

[–] [email protected] 3 points 3 days ago* (last edited 2 days ago) (2 children)

For i = 0; I < array.length; i++

[–] [email protected] 3 points 2 days ago (1 children)

Casually throws in capitals as well.

[–] [email protected] 2 points 2 days ago

My post is a work of fiction

[–] [email protected] 6 points 2 days ago

i < array.length or else you overflow.

[–] [email protected] 4 points 3 days ago

It doesn't make sense that the fourth element is element number 3 either.

Ultimately it's just about you being used to it.

[–] [email protected] 2 points 2 days ago (1 children)

Yeah, but if we went back and time and changed it then there wouldn't be other stuff relying on it being 0-based.

[–] [email protected] 4 points 2 days ago (1 children)

It was not randomly decided. Even before arrays as a language concept existed, you would just store objects in continuous memory.

To access you would do $addr+0, $addr+1 etc. The index had to be zero-based or you would simply waste the first address.

Then in languages like C that just got a little bit of syntactic sugar where the '[]' operator is a shorthand for that offset. An array is still just a memory address (i.e. a pointer).

[–] [email protected] 1 points 2 days ago (1 children)

I know. But in the alternate reality where we'd been using 1-based indices forever you'd be telling me how useful it is that the first element is "1" instead of zero and I'd be saying there are some benefits to using zero based index because it's more like an offset than an index.

[–] [email protected] 2 points 1 day ago

A lot of mathematical languages start from 1: R, Julia, Mathematica (and also Lua and Fish).

I don't know why, but in, e.g. R, it doesn't bother me, I get caught by it in Lua all the time.

I suppose it's a function of how far the array is abstracted from being pointers to an address that makes it easier to mentally switch.

load more comments (11 replies)