- Feature Articles
- CodeSOD
-
Error'd
- Most Recent Articles
- Secret Horror
- Not Impossible
- Monkeys
- Killing Time
- Hypersensitive
- Infallabella
- Doubled Daniel
- It Figures
- Forums
-
Other Articles
- Random Article
- Other Series
- Alex's Soapbox
- Announcements
- Best of…
- Best of Email
- Best of the Sidebar
- Bring Your Own Code
- Coded Smorgasbord
- Mandatory Fun Day
- Off Topic
- Representative Line
- News Roundup
- Editor's Soapbox
- Software on the Rocks
- Souvenir Potpourri
- Sponsor Post
- Tales from the Interview
- The Daily WTF: Live
- Virtudyne
Admin
MainFristThread1
Admin
Rex is right, threads are hard to understand. Rex is King!
Admin
Hey King (Rex), I know threads are hard for you to understand. just let the junior dev handle it, she may teach you a few things. :)
Admin
Quick show of hands: how many experienced DailyWTFers had the word "singleton" pop into their head the instant they saw "threads"?
Admin
This discussion thread was predictable
Admin
I always thought "T-rex" was short for "Tyrannosaurus-Rex"
turns out it's "Thread King Rex"
Admin
Especially when you can only have one at a time.
Admin
This discussion thread2 was predictable
Admin
Seriously, having slightly more threads than cores can be alright in order to use CPU cycles while some threads wait for I/O. Other than that, this is crazy.
I guess the idea was to avoid race conditions in global/static variables, because each thread gets its own copy this way, but (a) it doesn't seem to be implemented correctly as this bug shows and (b) if there only was a better way to bind data privately to specific instances of code -- unless the king would object ...
Admin
Epilogue: Alona was fired for questioning Rex's prowess
Admin
I once saw this approach of copying and pasting code 10 times delivered by Sapient. I was worried that it was typical offshore bad code quality but now I'm relieved that this approach is also taken by senior architects.
Admin
I am highly skeptical of this report. There's just no universe in which 20 identical subclasses make sense, no matter how badly you misunderstand threads.
Admin
I've found that if you design your classes with proper encapsulation and canonical use of getters and setters, most of the problems you get with multi-threading never arise in the first place. It's only when you try to mess about and do things manually so as to "optimize" that things start going haywire. And we all know what the three rules of optimization are, don't we, children?
Admin
It's not necessary even for I/O bound processing. Asynchronous I/O (e.g. Win32 Overlapped or Completion Ports) will manage that just fine. Waiting synchronously for I/O to complete? Why would you want to do that?
Admin
Bugger Off, I'm just making threading easy!
You fools.
Admin
Threads are free!
Admin
Alternate title suggestion: "Just Use It."
Admin
| Waiting synchronously for I/O to complete? Why would you want to do that?
Because it's simpler to develop, document, debug and maintain. If you have only a handful of threads in a typical app, the tied-up resources of an I/O bound thread are not significant.
In a busy ASP.NET app, it's a different story where async starts to make sense.
Admin
Because Java has great support for threads and no coroutines.
Admin
So what? You don't need coroutines to do asynchronous I/O.
Admin
"Rex" is of course a nickname, it's short for "he who rex exerything".
Admin
No, but Java doesn't really have any good support for async IO, coroutines or otherwise. It has the low-level primitives like NIO, but that's just the building blocks for an event loop... you're reliant on third-party libraries for any kind of usable API to code to. Forget about querying a relational database – JDBC is totally synchronous – unless again, you can dig out some libraries that provide a non-standard async API on top of your specific database. Supposedly there's a new async database API coming out of Oracle, but it's not here yet, and the way the JEE world has gone in recent years, I don't expect to see it in production this decade...
Admin
For largely I/O bound processing, yes. But for typical jobs which are mainly CPU bound, but do some occasional I/O (especially input), it's easier to use this time on other threads, rather than trying to fit some other jobs in. That's why I said "slightly".
Admin
Given that this decade ends in less than 17 months, I wouldn't either.
Admin
QFT. I've done async IO in Java and it was both weird and horrible. It's also terribly integrated with the old IO classes and some operations are only available on the old classes and others are only on the new ones… to say nothing of just how limited it all is (e.g., there's no async IO support for inter-process pipes out of the box). Grr…
Admin
private String rex = "Brillant";
Admin
You obviously have never worked for a megacorp. ;-)
Seriously, I have seen worse. It doesn't make sense, but then it doesn't have to.
Remember "A fundamental rule in technology says that whatever can be done will be done." - Andy Grove
Admin
Spring Data works well for me.
Admin
1243 lines of identical code? That's amazingly excellent. Any lesser programmer than Rex would have ended up with 17 sets of around 1240 lines of almost identical but subtly different code.
Admin
It's not that he misunderstood threads. He misunderstood singletons. Singletons: There can be only one. Not seventeen. Threadpool: Contains as many thread objects as you need.
Admin
"There's just no universe in which 20 identical subclasses make sense"
That's why it's on TheDailyWTF.com and not ITdecisionsThatMakeSense.com.
Admin
Yeah, there's some interesting stuff happening in third-party libraries... the new Reactor-based APIs that are going into Spring, for example. But those APIs don't help much if the underlying resource is still synchronous... for example, they work well with a MongoDB store, since that natively supports async - but anything connecting to a traditional RDBMS is going to be stuck with blocking IO...
Admin
So assign the threading bug to Rex, and move on. Clearly, no one else is qualified (in Rex's mind) to work on such things.
"Problem solved." >;->
Admin
| "There's just no universe in which 20 identical subclasses make sense"
Right! So refactor the 20 copies into a common base class, and have 20 [ completely pointless >;-> ] subclasses. There: "Problem solved; move on!" >;->
Admin
I was asked to work on a FOSS project by Red Hat, so I took a look at the code. It was heavily dependent on spring. So I looked at the source code for spring. Then I declined the offer.