Things you shouldn't do
Steve
dippyd at yahoo.com
Tue Mar 29 22:44:00 EST 2005
All names have been removed to protect the guilty :-)
In an earlier post, I read a piece of code:
>>> l1 = [1, 2, 3]
>>> l2 = [1, 2, 3]
>>> l1 == l2
True
I immediately gave a double-take: 11 equals 12? What
gives? Can you re-bind literals in Python???
>>> 11 = [1, 2, 3]
SyntaxError: can't assign to literal
And then it hit me. That wasn't eleven and twelve, the
variable names were lowercase L with the digits one and
two appended.
Imagine running a long piece of code on some test data
and finding an off-by-one bug which you think is on the
line "myvalue = something + l1". You change the eleven
to 12 and now the code works on your test data but not
for anything else.
If you have access to a syntax-aware editor, it will
help avoid such problems, but better to avoid them in
the first place. You might be reading code printed in
black and white on dead tree one day.
Lesson the first: remember that in many fonts, zero and
capital O are identical, as are lowercase L and 1 and
sometimes even uppercase I. Avoid using names which can
be easily confused for literals or for each other.
What are some of other people's favourite tips for
avoiding bugs in the first place, as opposed to finding
them once you know they are there?
--
Steven
More information about the Python-list
mailing list