variable scope in statement blocks

前端 未结 9 1827
梦如初夏
梦如初夏 2020-12-01 21:14
for (int i = 0; i < 10; i++)
{
    Foo();
}
int i = 10; // error, \'i\' already exists

----------------------------------------    

for (int i = 0; i < 10; i         


        
相关标签:
9条回答
  • 2020-12-01 22:13

    Me thinks that the compiler means to say that i has been declared at the method level & scoped to within the for loop.

    So, in case 1 - you get an error that the variable already exists, which it does

    & in case 2 - since the variable is scoped only within the for loop, it cannot be accessed outside that loop

    To avoid this, you could:

    var i = 0;
    
    for(i = 0, i < 10, i++){
    }
    
    i = 10;
    

    but I can't think of a case where you would want to do this.

    HTH

    0 讨论(0)
  • 2020-12-01 22:14

    By my understanding of scope, the first example should be fine.

    Your understanding of scope is fine. This is not a scoping error. It is an inconsistent use of simple name error.

    int i = 10; // error, 'i' already exists

    That is not the error that is reported. The error that is reported is "a local variable named i cannot be declared in this scope because it would give a different meaning to i which is already used in a child scope to denote something else"

    The error message is telling you what the error is; read the error message again. It nowhere says that there is a conflict between the declarations; it says that the error is because that changes the meaning of the simple name. The error is not the redeclaration; it is perfectly legal to have two things in two different scopes that have the same name, even if those scopes nest. What is not legal is to have one simple name mean two different things in nested local variable declarations spaces.

    You would get the error "a local variable named i is already defined in this scope" if instead you did something like

    int i = 10;
    int i = 10;
    

    Surely 'i' is either in scope or not.

    Sure -- but so what? Whether a given i is in scope or not is irrelevant. For example:

    class C 
    {
        int i;
        void M()
        {
            string i;
    

    Perfectly legal. The outer i is in scope throughout M. There is no problem at all with declaring a local i that shadows the outer scope. What would be a problem is if you said

    class C 
    {
        int i;
        void M()
        {
            int x = i;
            foreach(char i in ...
    

    Because now you've used i to mean two different things in two nested local variable declaration spaces -- a loop variable and a field. That's confusing and error-prone, so we make it illegal.

    Is there something non-obvious about scope I don't understand which means the compiler genuinely can't resolve this?

    I don't understand the question. Obviously the compiler is able to completely analyze the program; if the compiler could not resolve the meaning of each usage of i then how could it report the error message? The compiler is completely able to determine that you've used 'i' to mean two different things in the same local variable declaration space, and reports the error accordingly.

    0 讨论(0)
  • 2020-12-01 22:14

    Or is just a case of nanny-state compilerism?

    Exactly that. There is no sense in "reusing" variable names in the same method. It's just a source of errors and nothing more.

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