Practical rules for premature optimization
- by DougW
It seems that the phrase "Premature Optimization" is the buzz-word of the day.  For some reason, iphone programmers in particular seem to think of avoiding premature optimization as a pro-active goal, rather than the natural result of simply avoiding distraction.  The problem is, the term is beginning to be applied more and more to cases that are completely inappropriate.
For example, I've seen a growing number of people say not to worry about the complexity of an algorithm, because that's premature optimization (eg http://stackoverflow.com/questions/2190275/help-sorting-an-nsarray-across-two-properties-with-nssortdescriptor/2191720#2191720).  Frankly, I think this is just laziness, and appalling to disciplined computer science.
But it has occurred to me that maybe considering the complexity and performance of algorithms is going the way of assembly loop unrolling, and other optimization techniques that are now considered unnecessary.
What do you think?  Are we at the point now where deciding between an O(n^n) and O(n!) complexity algorithm is irrelevant?  What about O(n) vs O(n*n)?
What do you consider "premature optimization"?  What practical rules do you use to consciously or unconsciously avoid it?
This is a bit vague, but I'm curious to hear other peoples' opinions on the topic.