I have a class divided in two partial files, like this:
public partial class PersonRepository : BaseRepository
{
public static readonly str
public const string ColumnID = "ID";
readonly
The value of a readonly
field can be changed (in a constructor). You need a const
.
Try to change this
public static readonly string ColumnID = "ID";
to
public const string ColumnID = "ID";
const is something declared with const keyword.
readonly field can be assigned in constructor and its not compile time constant. the code that you've written right now runs in initializer (before constructor). const fields are 'baked' in as constants.
You must declare your ColumnID
as const
.
The static readonly
string will be instantiated when the class is first accessed in your code, and you could also initialize it with the return value of a static method, so it's not a compile-time constant for the compiler (even if in this case it obviously is for a person reading the code).
No, the expression PersonRespository.ColumnID
is not classified as a compile-time constant. The expression "ID" is, but that's not what you're using as the default parameter.
In particular, if ColumnID
is "just a normal field" then any references to it will be resolved as a field - so if you compile an assembly which refers to the field, then change the value and rebuild the assembly containing PersonRepository
, the referring assembly will see that change.
If you change your declaration to:
public const string ColumnID = "ID";
then it is a compile-time constant expression. That means in our previous scenario, the value of the constant is baked into any code that refers to it - and changing the value later without recompiling that referring code won't change the value used by that referring code.
See section 7.19 of the C# 4 language specification for more details about what counts as a constant expression.