19 March 2012 8 comments Python
We have a piece of code that is going to be run A LOT on a server infrastructure that needs to be fast. I know that I/O is much more important but because I had the time I wanted to figure out which is fastest:
def a(s, m): if len(s) > m: s = s[:m] return s
def b(s, m): return s[:m]
I wrote a simple benchmark that bombarded these two string manipulation functions with strings that were on average 50% chance longer than the max length. In other words, half of strings sent to these two functions where so short they didn't need to be truncated.
Turns out, there is absolutely no significant difference! I'm not even going to post the timings.
I could go on an repeat the iterations till my CPU starts to smoke but then I'm sure the benchmark is becoming invalid and needs to be re-engineered and by then the realm of the test becomes surreal. Now, carry on with your life of writing real code.Follow @peterbe on Twitter