💎一站式轻松地调用各大LLM模型接口,支持GPT4、智谱、星火、月之暗面及文生图 广告
# 使用 ref 和 out 传递数组(C# 编程指南) 与所有 [out](https://msdn.microsoft.com/zh-cn/library/t3c3bfhx.aspx) 参数一样,在使用数组类型的 **out** 参数前必须先为其赋值;即必须由被调用方为其赋值。例如: ``` static void TestMethod1(out int[] arr) { arr = new int[10]; // definite assignment of arr } ``` 与所有 [ref](https://msdn.microsoft.com/zh-cn/library/14akc2c7.aspx) 参数一样,数组类型的 **ref** 参数必须由调用方明确赋值。因此,不需要由被调用方明确赋值。可以将数组类型的 **ref** 参数更改为调用的结果。例如,可以为数组赋以 [null](https://msdn.microsoft.com/zh-cn/library/edakx9da.aspx) 值,或将其初始化为另一个数组。例如: ``` static void TestMethod2(ref int[] arr) { arr = new int[10]; // arr initialized to a different array } ``` 下面两个示例演示了 **out** 与 **ref** 在将数组传递给方法时的用法差异。 在此示例中,在调用方(Main 方法)中声明数组 theArray,并在 FillArray 方法中初始化此数组。然后,数组元素将返回调用方并显示。 ``` class TestOut { static void FillArray(out int[] arr) { // Initialize the array: arr = new int[5] { 1, 2, 3, 4, 5 }; } static void Main() { int[] theArray; // Initialization is not required // Pass the array to the callee using out: FillArray(out theArray); // Display the array elements: System.Console.WriteLine("Array elements are:"); for (int i = 0; i < theArray.Length; i++) { System.Console.Write(theArray[i] + " "); } // Keep the console window open in debug mode. System.Console.WriteLine("Press any key to exit."); System.Console.ReadKey(); } } /* Output: Array elements are: 1 2 3 4 5 */ ``` 在此示例中,在调用方(Main 方法)中初始化数组 theArray,并通过使用 **ref** 参数将其传递给 FillArray 方法。在 FillArray 方法中更新某些数组元素。然后,数组元素将返回调用方并显示。 ``` class TestRef { static void FillArray(ref int[] arr) { // Create the array on demand: if (arr == null) { arr = new int[10]; } // Fill the array: arr[0] = 1111; arr[4] = 5555; } static void Main() { // Initialize the array: int[] theArray = { 1, 2, 3, 4, 5 }; // Pass the array using ref: FillArray(ref theArray); // Display the updated array: System.Console.WriteLine("Array elements are:"); for (int i = 0; i < theArray.Length; i++) { System.Console.Write(theArray[i] + " "); } // Keep the console window open in debug mode. System.Console.WriteLine("Press any key to exit."); System.Console.ReadKey(); } } /* Output: Array elements are: 1111 2 3 4 5555 */ ``` ## 请参阅 [ref(C# 参考)](https://msdn.microsoft.com/zh-cn/library/14akc2c7.aspx) [out 参数修饰符(C# 参考)](https://msdn.microsoft.com/zh-cn/library/ee332485.aspx) [C# 编程指南](https://msdn.microsoft.com/zh-cn/library/67ef8sbd.aspx) [数组(C# 编程指南)](https://msdn.microsoft.com/zh-cn/library/9b9dty7d.aspx) [一维数组(C# 编程指南)](https://msdn.microsoft.com/zh-cn/library/0a7fscd0.aspx) [多维数组(C# 编程指南)](https://msdn.microsoft.com/zh-cn/library/2yd9wwz4.aspx) [交错数组(C# 编程指南)](https://msdn.microsoft.com/zh-cn/library/2s05feca.aspx)