Someone looking at the change will see just that one line and will immediately understand that the field separator changed from a semicolon to a pipe symbol. This way, when the field separator changes, you change exactly one line of code, the declaration of the constant. Private const int MaxFieldsPerRecord = 10 Private const char RecordSeparator = ' ' In the field-splitting application described above, the semicolon's purpose is a field separator, and the constants should be named accordingly: private const char FieldSeparator = ' ' // Will become '|' a month from now Identifiers for constants need to be descriptive of what the value does, not what the value is, and that's where your colleague has made a left turn into the weeds. At that rate you might as well have just used a literal semicolon ( ' ') in the first place, because you'll have to evaluate each use of it individually and you'll be making the same number of changes. To abate that, you could change the name of the literal to PipeSymbol and go through and change every occurrence of SemiColon to PipeSymbol. That will lead to negative comments in code reviews. Under the value-as-name scheme your colleague prefers, you'd have to change the value of the literal ( SemiColon = '|') and live with code that continues to use SemiColon for something that isn't really a semicolon anymore. If whoever wrote your spec calls you up a month from now and says, "we were mistaken, the fields in the records are separated by pipe symbols ( a|b|c d|e|f)," what do you do? Let's say your code's job is to parse a stream of records which contain fields separated by semicolons ( a b c) and are themselves separated by spaces ( a b c d e f). The argument you need to be making with your colleague isn't about naming a literal space as Space but his poor choice of name for his constants. when arguing with one of my collegues, who is going to the point ofĭeclaring constants like: private const char SemiColon = ' ' So my question is should be using magic strings and numbers in our code? I am specifically looking for expert answers that are backed by references if possible. There is many more articles, and after reading these some patterns emerge. I would like to do this to have some scientificaly-based arguments when arguing with one of my collegues, who is going to the point of declaring constants like: private const char SemiColon = ' ' Īnother example would be (and this one is in JavaScript): var someNumericDisplay = new NumericDisplay("#Div_ID_Here") ĭo you stick DOM IDs on top of your javascript file if that ID is used only in 1 place?
0 Comments
Leave a Reply. |