readonly(C# 参考)
Visual Studio 2015
说明 |
For the latest documentation on C#, visit the C# Guide on docs.microsoft.com. |
readonly 关键字是可以在字段上使用的修饰符。 当字段声明包括 readonly 修饰符时,该声明引入的字段赋值只能作为声明的一部分出现,或者出现在同一类的构造函数中。
示例
在此示例中,字段 year 的值无法在 ChangeYear 方法中更改,即使在类构造函数中给它赋了值。
C#
1 class Age 2 { 3 readonly int _year; 4 Age(int year) 5 { 6 _year = year; 7 } 8 void ChangeYear() 9 { 10 //_year = 1967; // Compile error if uncommented. 11 } 12 }
只能在下列上下文中对 readonly 字段进行赋值:
- 当在声明中初始化变量时,例如:
public readonly int y = 5; - 对于实例字段,在包含字段声明的类的实例构造函数中;或者,对于静态字段,在包含字段声明的类的静态构造函数中。 也只有在这些上下文中,将 readonly 字段作为 out 或 ref 参数传递才有效。
说明 |
readonly 关键字与 const 关键字不同。 const 字段只能在该字段的声明中初始化。 readonly 字段可以在声明或构造函数中初始化。 因此,根据所使用的构造函数,readonly 字段可能具有不同的值。 另外,const 字段为编译时常数,而 readonly 字段可用于运行时常数,如下例所示: |
public static readonly uint timeStamp = (uint)DateTime.Now.Ticks;
示例
C#
1 public class ReadOnlyTest 2 { 3 class SampleClass 4 { 5 public int x; 6 // Initialize a readonly field 7 public readonly int y = 25; 8 public readonly int z; 9 public SampleClass() 10 { 11 // Initialize a readonly instance field 12 z = 24; 13 } 14 public SampleClass(int p1, int p2, int p3) 15 { 16 x = p1; 17 y = p2; 18 z = p3; 19 } 20 } 21 static void Main() 22 { 23 SampleClass p1 = new SampleClass(11, 21, 32); // OK 24 Console.WriteLine("p1: x={0}, y={1}, z={2}", p1.x, p1.y, p1.z); 25 SampleClass p2 = new SampleClass(); 26 p2.x = 55; // OK 27 Console.WriteLine("p2: x={0}, y={1}, z={2}", p2.x, p2.y, p2.z); 28 } 29 } 30 /* 31 Output: 32 p1: x=11, y=21, z=32 33 p2: x=55, y=25, z=24 34 */
在前面的示例中,如果使用这样的语句:
p2.y = 66; // Error
将收到编译器错误信息:
The left-hand side of an assignment must be an l-value
这与尝试将值赋给常数时收到的错误相同。
来自 <https://msdn.microsoft.com/zh-cn/library/acdd6hb7.aspx>