laziness, impatience, and hubris | |
PerlMonks |
comment on |
( [id://3333]=superdoc: print w/replies, xml ) | Need Help?? |
1. I don't know of any way to cause a hash key to be created by use of an "if" test.
Correct. There isn't. An other operator has to come into play. However, the following fools many since the operator is invisible: if ($hash{foo}{bar}) download See my reply to the OP. Interesting...I will have to experiment with this. 2nd hash dimension wasn't part of the question. 2. I don't know of any way to cause a hash key's value to be "non-existant".
I'm only on 5.10, so learned something new. Update: still don't see it, ie. how to leave the key but have the value of that key be anything other than undef,string(null or not) or number. To the best of my knowledge a hash key will always evaluate to at least undef. delete $hash{foo} removes key foo and its value. When you test a hash key, you are testing the value of the key. It can be true or false. false values are: "undef","",'',0
The string "undef" isn't false. Plain old undef is, though. The second and third literal you posted are the same value.
And you're missing some. Except for some insane situations, anything that stringifies to "" or "0" is false. The common false values are undef, the empty string, 0 and "0".
4. If a hash key value "exists" then it can have any one of the 4 values above.
Not true. Aside from the fact that you only listed three values, a hash value can be an scalar, not just false ones.
5. If a hash key value is "defined", then there only 3 possibilities.
Not true. It can be any scalar value except undef.
Thanks for your clarifications. In reply to Re^3: Best Hash Practices?
by Marshall
|
|