当前位置: 首页 > 编程笔记 >

C#中参数数组、引用参数和输出参数示例详解

栾英资
2023-03-14
本文向大家介绍C#中参数数组、引用参数和输出参数示例详解,包括了C#中参数数组、引用参数和输出参数示例详解的使用技巧和注意事项,需要的朋友参考一下

前言

本文主要介绍了关于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”。 某些类型是可变的,在这种情况下,您可以修改传递给函数的对象。对于不可变的类型(例如),您必须构建某种包装类,而可