Understanding Values and References in Microsoft Visual C#
- 11/18/2015
Quick reference
To |
Do this |
Copy a value type variable |
Simply make the copy. Because the variable is a value type, you will have two copies of the same value. For example: int i = 42; int copyi = i; |
Copy a reference type variable |
Simply make the copy. Because the variable is a reference type, you will have two references to the same object. For example: Circle c = new Circle(42); Circle refc = c; |
Declare a variable that can hold a value type or the null value |
Declare the variable by using the ? modifier with the type. For example: int? i = null; |
Pass an argument to a ref parameter |
Prefix the argument with the ref keyword. This makes the parameter an alias for the actual argument rather than a copy of the argument. The method may change the value of the parameter, and this change is made to the actual argument rather than to a local copy. For example: static void Main() { int arg = 42; doWork(ref arg); Console.WriteLine(arg); } |
Pass an argument to an out parameter |
Prefix the argument with the out keyword. This makes the parameter an alias for the actual argument rather than a copy of the argument. The method must assign a value to the parameter, and this value is made to the actual argument. For example: static void Main() { int arg; doWork(out arg); Console.WriteLine(arg); } |
Box a value |
Initialize or assign a variable of type object with the value. For example: object o = 42; |
Unbox a value |
Cast the object reference that refers to the boxed value to the type of the value variable. For example: int i = (int)o; |
Cast an object safely |
Use the is operator to test whether the cast is valid. For example: WrappedInt wi = new WrappedInt(); ... object o = wi; if (o is WrappedInt) { WrappedInt temp = (WrappedInt)o; ... } Alternatively, use the as operator to perform the cast, and test whether the result is null. For example: WrappedInt wi = new WrappedInt(); ... object o = wi; WrappedInt temp = o as WrappedInt; if (temp != null) ... |