前言
本文主要介绍了关于C#参数数组、引用参数和输出参数的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧
参数数组
在C#中,可以为函数指定一个不定长的参数,这个参数是函数定义中的最后一个参数,这个参数叫做参数数组。
下面是一个例子:
namespace Ch6Ex2 { class Program { static int SumVals(params int[] vals) { int sum = 0; foreach (int val in vals) { sum += val; } return sum; } static void Main(string[] args) { int sum = SumVals(1, 2, 3, 4, 5); Console.WriteLine($"Summed Values = {sum}"); Console.ReadKey(); } } }
函数SumVals有一个参数数组,即vals,在定义该参数时,需要使用params参数。在调用该函数时,可以给参数输入传入多个实参。
使用分散式传参时,编译器做如下事:
1)接受实参列表,用它们在堆中创建并初始化一个数组。
2)把数组的引用保存到栈中的形参里。
3)如果在对应的形参数组的位置没有实参,编译器会创建一个有零个元素的数组来使用。
4)如果数组参数是值类型,那么值被复制,实参不受方法内部的影响。
5)如果数组参数是引用类型,那么引用被复制,实参引用的对象可以受到方法内部的影响。
在使用数组式传参时,编译器使用你的数据而不是重新创建一个。即相当引用参数。
引用参数
可以通过引用传递参数,需要使用ref关键字。
下面是一个例子:
namespace MyProgram { class Program { static void SwapInts (ref int a, ref int b) { int temp = b; b = a; a = temp; } static void Main(string[] args) { int a = 1; int b = 2; Console.WriteLine($"a = {a}, b = {b}"); SwapInts(ref a, ref b); Console.WriteLine($"a = {a}, b = {b}"); Console.ReadKey(); } } }
这是一个简单的交换两个值的程序,由于函数SwapInts使用了引用参数,所以可以在函数中修改变量a和b的值,需要注意的是,在调用函数时也要使用ref传递引用参数。
输出参数
输出参数使用out关键字,它的效果与引用参数几乎相同,不同点是:
下面是一个例子:
namespace MyProgram { class Program { static int MaxValue (int[] intArray, out int maxIndex) { int maxValue = intArray[0]; maxIndex = 0; for (int i = 0; i < intArray.Length; i++) { if (intArray[i] > maxValue) { maxValue = intArray[i]; maxIndex = i; } } return maxValue; } static void Main(string[] args) { int maxIndex; int[] intArray = { 12, 45, 23, 77, 73 }; int maxValue = MaxValue(intArray, out maxIndex); Console.WriteLine($"maxValue = {maxValue}, maxIndex = {maxIndex}."); Console.ReadKey(); } } }
这个函数将一个数组中最大值的索引作为输出参数,返回最大值。
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对小牛知识库的支持。
某些情况下,我们在定义函数时可能并不能提前确定参数的数量,这时可以使用 C# 提供的参数数组,参数数组通常用于为函数传递未知数量的参数。 若要使用参数数组,则需要利用 params 关键字,语法格式如下: 访问权限修饰符 返回值类型 函数名(params 类型名称[] 数组名称) 提示:使用参数数组时,既可以直接为函数传递一个数组作为参数,也可以使用的形式传递若干个具体的值作为参数。 下面通过示例
问题内容: 我想从查询中获取ID,但是我得到的是NULL,我的错误在哪里? 为什么@Id参数始终为null?我看不到我的错误? 问题答案: 首先,选择所希望的使用的输出变量然后分配该中值使用可变。另外,您应该使用变量在where子句中传递数据,以避免类似sql的注入问题(即,您不应像那样将其串联起来)。试试这个 : 在这里查看详细信息
问题内容: 我有一个功能可以做到这一点: 哪个发送到我的数据库类,它执行以下操作: 问题是这不起作用。 我希望做的是获取列表,并在后面列出它们,以使查询类似于: 但是很明显,我走错了路。 有没有办法使数组…按原样转换为要在查询阶段打印出来的列表? 问题答案: call_user_func_array “使用参数数组调用回调” 应该做的工作 更新 :您还必须更改您的params数组: 如预期的那样,
问题内容: 我正在努力查看将值传递给函数时使用哪种方法是否有明显的优势。下面的代码可能不是解释我要做出的决定的最佳示例,但我认为这是最容易理解的示例。 可变参数方法 数组参数法 两种技术中的哪一种是首选?如果是这样,为什么(速度,可靠性或只是易于阅读)?谢谢。 问题答案: 我认为没有速度差异。因为,在功能内部,您可以像一样使用。 我认为如果参数数量较少(例如小于5个),则因为易于阅读,可能是一个更
我的理解是,当编写gcc样式的内联asm时,您必须非常具体和准确地了解所有的输入和输出参数(和clobbers),这样编译器就会确切地知道如何为代码分配寄存器,以及它可以对那些寄存器的值和asm代码可能读取和/或修改的任何内存假设什么。编译器使用这些信息尽可能地优化周围的代码(如果它认为内联asm对任何东西都没有影响,甚至完全删除它)。对此不够具体可能会导致不正确的行为,因为编译器是根据您的不正确
问题内容: 使用第三方API,我观察到以下内容。 而不是使用 它使用类似 我得到分配的“输出”字符串。 我很好奇实现这种功能的原因。使用此类输出参数的优点是什么? 问题答案: 在您的示例中有不对的地方。 在上面的程序中,将输出字符串“ foo”, 而不是 “ Hello World”。 某些类型是可变的,在这种情况下,您可以修改传递给函数的对象。对于不可变的类型(例如),您必须构建某种包装类,而可