[Python-Dev] redefining is
Guido van Rossum
guido at python.org
Thu Mar 18 12:08:12 EST 2004
> There is an idiom (I've seen it more in Lisp than in python)
> of creating a fresh object to act as a sentinel.
>
> "done with this data" might well appear in the input, but
> the specific newly-created-string (which happens to look
> just like that) can't appear.
>
> The sentinal is usually a mutable object, but it is sometimes
> a string indicating the object's meaning. ("fail") It is
> surprising that some objects (like small integers) cannot be
> used, but I don't think the answer is to make the entire
> idiom unusable.
Sorry, if you're usign *any* immutable value there and expecting it to
be a unique object, you're cruisin' for a bruisin', so to speak. The
language spec explicitly *allows* but does not *require* the
implementation to cache and reuse immutable values.
> You could argue that they ought to be using (id(x) == id(y))
> to emphasize that == isn't enough, but ... (x is y) seems
> just as clear, and the reference manual (5.9) says that is
> tests for object identity.
Please, just use None, [] or object() as a sentinel if you're going to
compare using 'is'.
--Guido van Rossum (home page: http://www.python.org/~guido/)
More information about the Python-Dev
mailing list