Very often, I use short variable names such as 'i', 'ctr', 'idx'. As you can tell from the name, generally these are used for iterating through a collection.
For me, I will use one of these if it's something quick and easy such as a fairly simple sort or filtering. Generally these are short (there are maybe one or two lines of code) and there aren't any other variables used.
Similarly for 'var', a C#-specific feature which I tend to use when working with LINQ but don't really need to keep the intermediate results. If I need the results, I usually convert to a List and that has a fairly descriptive name as well.
I also use it in GUI programming with Button events. Again, it's only a few lines of code and I only need it a few times at most. Most of the time, it's just created so I can call Show(). You could just create it without assigning it to a variable but it's not that at all difficult and could come in handy later if debugging is needed.
I would not recommend these for any code that spans more than maybe 1/2 a code page or for things that you can't understand what the code is doing within a few seconds, like algorithms.
Speaking of algorithms, some people like using names like 'a', 'b', 'c' but most algorithms are long and/or hard to understand. Usually for things like nested loops or involve a lots of other variables, I use better names.
For example, iterating through a table, I will use 'row', or 'col' if I am doing a lot with the data. If it's just a simple copy, probably 'r', 'c' is good enough.
But going back to algorithms particularly, I try to use names that are more descriptive so that people, myself included when I'm reviewing the code, don't need to spend 10 minutes figuring out what each one means.
I have spent a lot of time walking through code to figure out what it does because other developers have done and furthermore they don't even leave any comments. That's another thing, if something is complicated, or goes against usual conventions for some reason, leave a good comment that will let others or yourself immediately understand what's going on.
 
No comments:
Post a Comment