this post was submitted on 22 Jan 2025
414 points (99.1% liked)

memes

11090 readers
2414 users here now

Community rules

1. Be civilNo trolling, bigotry or other insulting / annoying behaviour

2. No politicsThis is non-politics community. For political memes please go to [email protected]

3. No recent repostsCheck for reposts when posting a meme, you can only repost after 1 month

4. No botsNo bots without the express approval of the mods or the admins

5. No Spam/AdsNo advertisements or spam. This is an instance rule and the only way to live.

Sister communities

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

For a sufficiently defined "goingToCrashIntoEachOther" and "don't", isn't that basically how it works?

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

Well, even at that level of abstraction, it's a bit weird, because goingToCrashIntoEachOther and dont() both need the information from where a collision is going to take place, so you'd expect something to be passed into dont().

Well, and it's easy to dismiss this stuff as implementation details, but that if-statement needs to run as part of a loop. This loop should probably be on a separate thread, so it doesn't get blocked by other stuff going on. Which means access to the motors needs to be behind some form of mutex, which it needs to be able to acquire fairly quickly. And then, yeah, those implementation details quickly add up to become the part that's actually complex.

[–] [email protected] 5 points 6 hours ago

It definitely should be, but at some point in time, very intelligent people though that this was a Good Thing:

bReadLine(bPort,&arru8NumberList)