190
submitted 8 months ago* (last edited 8 months ago) by kyub@discuss.tchncs.de to c/programmer_humor@programming.dev

you are viewing a single comment's thread
view the rest of the comments
[-] Vigge93@lemmy.world 4 points 8 months ago* (last edited 8 months ago)

I think it does make sense, it's a "did this loop exit naturally? If so, do x". This makes a lot of sense if you, for example, have a loop that checks a condition and breaks if that condition is met, e.g. finding the next item in a list. This allows for the else statement to set some default value to indicate that no match was found.

Imo, the feature can be very useful under certain circumstances, but the syntax is very confusing, and thus it's almost never a good idea to actually use it in code, since it decreases readability a lot for people not intimately familiar with the language.

Edit: Now, this is just guessing, but what I assume happens under the hood is that the else statement is executed when the StopIteration exception is recieved, which happens when next() is called on an exhausted iterator (either empty or fully consumed)

[-] Saleh@feddit.org 1 points 8 months ago* (last edited 8 months ago)

Couldn't you just handle this with:


breakflag = False

for x in iterator:

     if breakcondition(x):
            breakflag = True
            break  
     dostuff()
[-] lugal@sopuli.xyz 1 points 8 months ago

Thinking about it, it totally makes sense and has in inherent logic, even tho it's not intuitive

this post was submitted on 04 Feb 2025
190 points (100.0% liked)

Programmer Humor

27029 readers
636 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