Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Spec seems to allow readonly fields of instances other than 'this' to be assigned in constructors #1235

Open
jnm2 opened this issue Dec 12, 2024 · 0 comments

Comments

@jnm2
Copy link
Contributor

jnm2 commented Dec 12, 2024

https://github.com/dotnet/csharpstandard/blob/standard-v7/standard/classes.md#1553-readonly-fields:

When a field_declaration includes a readonly modifier, the fields introduced by the declaration are readonly fields. Direct assignments to readonly fields can only occur as part of that declaration or in an instance constructor or static constructor in the same class. (A readonly field can be assigned to multiple times in these contexts.) Specifically, direct assignments to a readonly field are permitted only in the following contexts:

  • In the variable_declarator that introduces the field (by including a variable_initializer in the declaration).
  • For an instance field, in the instance constructors of the class that contains the field declaration; for a static field, in the static constructor of the class that contains the field declaration. These are also the only contexts in which it is valid to pass a readonly field as an out or ref parameter.

Attempting to assign to a readonly field or pass it as an out or ref parameter in any other context is a compile-time error.

I didn't see how this spec text disallows the following assignment to a readonly field, which occurs in an instance constructor in the same class:

public class C
{
    private readonly int f;
    
    public C(C other)
    {
        other.f = 42;
    }
}

Which in practice (SharpLab) gives:

error CS0191: A readonly field cannot be assigned to (except in a constructor or init-only setter of the type in which the field is defined or a variable initializer)

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

1 participant