调用方法时,常给某个参数传入相同的值。例如,这可能是一个布尔值,以控制方法操作中的不重要部分。具体而言,考虑下面的方法定义:
public List<string> GetWords(string sentence, bool capitalizeWords)
{
...
}
无论给capitalizeWonis参数传入什么值,这个方法都会返回一系列string值,每个string值都是输入句子中的一个单词。根据这个方法的使用方式,可能需要把返回的单词列表转换为大写(也许要格式化一个标题)。但大多数情况下并不需要这么做,所以大多数调用如下所示:
List<string> words = GetWords(sentence, false);
为了将这种方式变成“默认”方式,可以声明第二个方法,如下所示:
public List<string> GetWords{string sentence) => GetWords(sentence, false);
这个方法调用第二个方法,并给capitalizeWords传入值false。
这么做没有任何错误,但可以想象在使用更多的参数时,这种方式会非常复杂。
另一种方式是把capitalizeWoids参数变成可选参数。这需要在方法定义中为参数提供一个默认值,使其成为可选参数,如果调用此方法时没有为该参数提供值,就使用默认值,如下所示:
public List<string> GetWords (string sentence, bool capitalizeWords = false)
{
...
}
如果以这种方式定义方法,就可以提供一个或两个参数,只有希望capitalizeWords是true时,才需要第二个参数。
1.可选参数的值
为方法定义可选参数的语法如下所示:
<parameterType> <parameterName> = <defaultValue>
对于<defcUltVah^>的默认值,存在一些限制。默认值必须是字面值、常量值或者默认值类型值。因此不会编译下面的代码:
public bool CapitalizationDefault;
public List<string> GetWords(string sentence,
bool capitalizeWords = CapitalxzationDofault)
{
...
}
为使上述代码可以工作,CapitalizationDefiiult值必须定义为常量:
public const bool CapitalizationDefault = false;
这样做是否有意义取决于具体情形,大多数情况下,最好提供一个字面值,就像上一节那样。
2.Optional 特性
除了前面小节中描述的语法,还可以使用Optional特性定义可选参数,如下所示:
[Optional] <parameterType> <parameterName>
此特性包含在System.Runtime.InteropServices名称空间中。注意,如果使用这种语法,就无法为参数提供默认值。
3.可选参数的顺序
使用可选值时,它们必须位于方法的参数列表末尾。没有默认值的参数不释放在有默认值的参数后面。因此下面的代码是非法的:
public List<string> GetWords(bool capitalizeWords = false, string sentence)
{
...
}
其中,sentence是必选参数,因此必须放在可选参数capitalizedWords的前面。
已有 22658 名学员学习以下课程通过考试
最需教育客户端 软件问题一手掌握
去 App Store 免费下载 iOS 客户端
点击加载更多评论>>