使用lambda表达式而不是foreach是一种好习惯吗?

Cat*_*oha 6 c# linq foreach lambda

今天我正在开发一个TextToSpeech应用程序,我遇到了一种情况,我需要检查用户选择的语音是否安装在计算机上.

为此,我可以使用foreach:

bool foundVoice = false;
foreach (var v in installedVoices)
{
    if (v.VoiceInfo.Name.Contains(selectedVoice) && v.VoiceInfo.Culture.ToString() == selectedCulture)
    {
        foundVoice = true;
        break;
    }
}
Run Code Online (Sandbox Code Playgroud)

lamda表达式:

var foundVoice = installedVoices.FirstOrDefault(v => v.VoiceInfo.Name.Contains(selectedVoice) && v.VoiceInfo.Culture.ToString() == selectedCulture);
Run Code Online (Sandbox Code Playgroud)

installedVoices是来自SpeechSynthesizerReadOnlyCollection <InstalledVoice>.

毫无疑问,lambda表达式看起来比foreach更干净,但哪一种更好用?

根据我的测试,foreach似乎比lambda表达式快.

此外,如果需要对InstalledVoice立即采取行动,将来可以扩展foreach和lambda.

das*_*ght 7

lambda表达式看起来比foreach更干净但哪一个更好的做法?

"看起来更干净"是更好实践的完美指标.根据所使用的语言设施,以极有意义的方式更改性能极为罕见,因此可读性是衡量特定构造对代码有多好的最重要指标.可读性最终决定了代码的可维护性,即使代码的唯一读者是您.

请注意,这是一个逐案判断,因为在一种情况下lambdas可能更好,而在另一种情况下循环可能更好.