I've never seen much value in Hungarian notation, myself. If I want to
know whether a variable is global/local or what it's data type is, I'll
just go look... honestly, I rarely get confused by something like that,
and if I do, looking it up isn't that difficult.
The problem I always have -- particularly in ILE programming -- is
conflicts with other constants. For example, in my copybook for my
service program, I define a constant named SUCCESS and FAIL. Then some
other programmer writes a service program and also codes SUCCESS and
FAIL... now I can't include both copy books in the same caller,
because they have duplicate definitions.
It's especially a problem when expanding an existing tool. I might add
new constants to my service program and release an updated version....
existing callers might work if I don't recompile them, but they might
hit a conflict years later when they're next recompiled... So the
initial test of the program was okay, but a minor update causes a
failure later... what should've been a simple project becomes a headache.
So I tend to use a prefix that relates to the service program. Each
service program in our system has a unique prefix, like say, PURCH is
used for the purchase order service program. the constants (as well as
prototypes, data structure templates, module names, etc) are all
prefixed by PURCH.. and you have PURCH_SUCCESS and PURCH_FAIL. That
way, it never conflicts, because other service programs don't start with
PURCH.
To me, that's far more valuable than hungarian notation.
For locally-defined constants, the name of the constant doesn't matter
so much... there's rarely a conflict, and assuming you don't use a
stupid name like your gA = 'A' example, they're easy enough to
understand. So we don't really have any sort of naming standard for those.
I also prefer to type my constant names in ALL_UPPER_CASE, and type my
variables in MixedCase or lowercase. That way, there's a visual clue
that you're working with a constant vs. a variable.
David FOXWELL wrote:
Hi people,
I'd like some comments concerning the use of constants. I've been asked to prepare a presentation to the team for a discussion on good coding practices, as the boss is getting tired of seeing this sort of thing :
* Global figurative constants
* Type relation = aunt
D gA C 'A'
myRelation = gA;
Now, I'd have written :
D gAUNT C 'A'
D gUNCLE C 'U'
myRelation = gAUNT;
Some questions :
I would normally not use a commentaire at the declaration of a constant. What do you think?
We use a prefix g to indicate a globally defined constant, and w for a locally defined one. When would you locally define a constant in a sub procedure? I think it's nice to be able to see the definitions close to the calculation specs, but isn't a constant almost always global?
What is meant by figurative constant? I thought it was one with a fixed value like *BLANK.
Thanks
As an Amazon Associate we earn from qualifying purchases.