In case you are serious: It’s probably not.
When you’re not careful with parallel processing / multithreading, you can run into something called a “race condition”, where results of parallel computations end up in the wrong order because some were finished faster than others.
The joke here is that whoever “programmed” this commic is bad at parallel progmming and got the bubbles in the wrong order because of that.
The image makes perfect sense if you read it in the order 3, 1, 2.
I think that’s part of the joke too. Like the whole comic has been written out of order due to race conditions; rather than just the father represents race conditions.
It’s one degree of humour too far though, if that’s the case, doesn’t really land.
🤦🏽♀️ Thanks for explaining, my brain must have corrected the race condition.
Regarding threads: I have had good experience with using thread safe queues everywhere to exchange data between threads, it’s the right tool in many cases, but I doubt queues to be useful when coding for performance.
Could be I was not clear when I wrote performance, I am talking about High Performance Computing, where you want to spend all CPU cycles on solving your problem. While taking Amdal’s Law into account. https://en.wikipedia.org/wiki/Amdahl’s_law
In case you are serious: It’s probably not.
When you’re not careful with parallel processing / multithreading, you can run into something called a “race condition”, where results of parallel computations end up in the wrong order because some were finished faster than others.
The joke here is that whoever “programmed” this commic is bad at parallel progmming and got the bubbles in the wrong order because of that.
The image makes perfect sense if you read it in the order 3, 1, 2.
Apart from the fact that bubble 1 and 2 point to the wrong person.
I think that’s part of the joke too. Like the whole comic has been written out of order due to race conditions; rather than just the father represents race conditions.
It’s one degree of humour too far though, if that’s the case, doesn’t really land.
It definitely landed for me. The aspect of one thread coming out of a totally different routine for no reason was extra funny.
🤦🏽♀️ Thanks for explaining, my brain must have corrected the race condition.
Regarding threads: I have had good experience with using thread safe queues everywhere to exchange data between threads, it’s the right tool in many cases, but I doubt queues to be useful when coding for performance.
Umm, queueing is standard practice particularly when a task is performance intensive and needs limited resources.
Basically any programming language using any kind of asynchronous runtime is using queues in their scheduler, as well.
Could be I was not clear when I wrote performance, I am talking about High Performance Computing, where you want to spend all CPU cycles on solving your problem. While taking Amdal’s Law into account. https://en.wikipedia.org/wiki/Amdahl’s_law