按值传递、按引用传递这是方法传递参数的两种方式,而值类型和引用类型则是两种不同的类型体系。
可以按值传递的方式传递值类型和引用类型参数。
传递值类型参数
实例1:
class PassingValByVal { static void SquareIt(int x) // 按值传递值类型参数 // 对x的更改仅仅是针对其副本,而不会改变初始对象 { x *= x; System.Console.WriteLine("方法内的值: {0}", x); } static void Main() { int n = 5; System.Console.WriteLine("调用方法之前的值: {0}", n); SquareIt(n); // Passing the variable by value. System.Console.WriteLine("调用方法之后的值: {0}", n); // Keep the console window open in debug mode. System.Console.WriteLine("按任意键退出."); System.Console.ReadKey(); } } /* 输出结果: 调用方法之前的值: 5
方法内的值: 25
调用方法之后的值: 5
*/
传递引用类型参数
引用类型的变量不直接包含其数据;它包含的是对其数据的引用。当通过值传递引用类型的参数时,有可能更改引用所指向的数据,如某类成员的值(如上一篇示例中arr[0]的值)。但是无法更改引用本身的值;也就是说,不能使用相同的引用为新类分配内存并使之在块外保持(有点拗口,其实意思就是不能在初始对象上再new一个实例出来,由于我们平时使用string直接赋值而没有使用new所以一定程度上迷惑了我们。string也和其他引用类型一样,一旦赋值就重新分配了内存)若要这样做,应使用 ref 或 out 关键字传递参数。
下面的示例演示通过值向 Change 方法传递引用类型的参数 arr。由于该参数是对 arr 的引用,所以有可能更改数组元素的值。但是,试图将参数重新分配到不同的内存位置时,该操作仅在方法内有效,并不影响原始变量 arr。
class PassingRefByVal { static void Change(int[] pArray) { pArray[0] = 888; // 改变了数组的首项 pArray = new int[5] {-3, -1, -2, -3, -4}; // 使用相同的引用分配内存 System.Console.WriteLine("方法内部,数组首项: {0}", pArray[0]); } static void Main() { int[] arr = {1, 4, 5}; System.Console.WriteLine("调用方法之前首项: {0}", arr [0]); Change(arr); System.Console.WriteLine("调用之后的首项: {0}", arr [0]); } } /* Output: 调用方法之前首项: 1
方法内部,数组首项: -3
调用之后的首项: 888
*/