Search code examples
c#language-designscope

Why can't we define a variable inside an if statement?


Maybe this question has been answered before, but the word if occurs so often it's hard to find it.

The example doesn't make sense (the expression is always true), but it illustrates my question.

Why is this code valid:

StringBuilder sb;
if ((sb = new StringBuilder("test")) != null) {
    Console.WriteLine(sb);
}

But this code isn't:

if ((StringBuilder sb = new StringBuilder("test")) != null) {
    Console.WriteLine(sb);
}

I found a similar question regarding a while statement. The accepted answer there says that in a while statement, it would mean the variable would be defined in each loop. But for my if statement example, that isn't the case.

So what's the reason we are not allowed to do this?


Solution

  • This is because section 8.5.1 of the C# language spec. states:

    Furthermore, a variable initializer in a local variable declaration corresponds exactly to an assignment statement that is inserted immediately after the declaration.

    This basically means that, when you do:

    StringBuilder sb = new StringBuilder("test")
    

    You're, in effect, doing the exact same thing as:

    StringBuilder sb; sb = new StringBuilder("test")
    

    As such, there is no longer a return value for your check against != null, as the assignment isn't a single expression, but rather a statement, which is a local-variable-declarator comprised of an identifier followed by an expression.

    The language specification gives this example, stating that this:

    void F() {
       int x = 1, y, z = x * 2;
    }
    

    Is exactly equivalent to:

    void F() {
       int x; x = 1;
       int y;
       int z; z = x * 2;
    }