in reply to Re^5: The Null Mull (or, when OO needs more O)
in thread The Null Mull (or, when OO needs more O)
A further look with B::Concise show that subsequent, simple assignments to $x also worked. It appears that because my $x is equivalent to my $x = undef, perl didn't bother actually writing the = undef part to the variable already guaranteed to be undef anyway. So its an optimization.
I'd like to note that no one should ever actually attempt to overload undef in anything outside obfuscations. Since undef is a process wide global in way that even normal globals aren't global, you're propogating this new, defined value to every other module that's being used in your code. Now everything that used to return undefined to indicate failure will automatically signal success on failure, anyone using undef() as a parameter to select() for a sleep() will find themselves testing actual file handles. This is a seriously bad design decision that will warp the hell out of any process that uses it. Its cute for trying things like this out but no one should ever, ever, ever actually do this.
|
---|
Replies are listed 'Best First'. | |
---|---|
Re^7: The Null Mull (or, when OO needs more O)
by dragonchild (Archbishop) on Nov 30, 2004 at 14:22 UTC | |
by diotalevi (Canon) on Nov 30, 2004 at 14:32 UTC | |
by dragonchild (Archbishop) on Nov 30, 2004 at 14:51 UTC | |
by diotalevi (Canon) on Dec 01, 2004 at 02:50 UTC |