Local variables or direct statements?

前端 未结 7 1550
旧时难觅i
旧时难觅i 2021-01-25 23:55

I am currently studying C# and I really want to get a good coding style from the beginning, so I would like to hear opinions from you professionals on this matter.

Shoul

相关标签:
7条回答
  • 2021-01-26 00:23

    I suggest you use a local variable like here:

    bool parseSuccess = double.TryParse(stringToParse, out dblValue);
    if (parseSuccess) ...
    

    For two reasons:

    1. You can use more times the variable without parse your double another time.

    2. It makes the code more readable.

    Consider this:

    if(double.TryParse(string1, out Value1) && double.TryParse(string2, out Value2) && double.TryParse(string3, out Value3) && double.TryParse(string4, out Value4))
    {
        //some stuff
    }
    

    It's too long and it makes the code hard to be read. So sometimes local variabels make the code a lot more readable.

    0 讨论(0)
  • 2021-01-26 00:25

    As you said you are studying C#

    So my vote will be this style for you

    bool parseSuccess = double.TryParse(stringToParse, out dblValue);
    if (parseSuccess) ...
    

    If you are studying you will have lot to learn and the above style clearly tells you that TryParse return a bool, so you won't have to worry or find whats the return type for TryParse

    0 讨论(0)
  • 2021-01-26 00:28

    The clarity of the source code is an important parameter especially in application maintenance but so is performance.

    Insignificant it may seem, sometimes using simple syntax "tricks" of programming languages​​, we get very good results.

    If I think I'll use later in the code somehow the result, I use variables, otherwise I give priority to direct sentences.

    0 讨论(0)
  • 2021-01-26 00:39

    I see a lot of example 1 in production code. As long as the expression is simple, and it's easy to understand the logic of what's happening, I don't think you'll find many people who think it is bad style.

    Though you will probably find a lot of people with different preferences. :)

    0 讨论(0)
  • 2021-01-26 00:40

    You should use the more verbose style if putting it all in one line would make it too long or complicated.

    You should also use a separate variable if the variable's name would make it easier to understand the code:

    bool mustWait = someCommand.ConflictsWith(otherCommand);
    if (mustWait) {
        ...
    }
    

    In such cases, you should consider using an enum for additional readability.

    0 讨论(0)
  • 2021-01-26 00:45

    There's no right option. Both are perfectly acceptable.

    Most people choose the first option if you don't have a lot of conditions to concatenate because it results in less lines of code.

    0 讨论(0)
提交回复
热议问题