簡體   English   中英

選擇where子句的結果

[英]Select result of where clause

采取這種方法fe:

public static Function Parse(string codeAndData)
{
    return (from factory in factories
            where factory.Parse(codeAndData) != null
            select factory.Parse(codeAndData)).FirstOrDefault();
}

如您所見, factory.Parse(codeAndData)被調用了兩次,這是不好的做法。 因此我們可以這樣寫:

public static Function Parse(string codeAndData)
{
    Function function = null;
    return (from factory in factories
            where (function = factory.Parse(codeAndData)) != null
            select function).FirstOrDefault();
}

但是以上對我來說似乎不是很優雅。 有沒有更好的LINQ替代方案?

使用方法鏈接語法很容易:

return factories.Select(f => f.Parse(codeAndData))
                .FirstOrDefault(p => p != null);

使用comprehension語法,您可以使用let來實現:

return (from factory in factories
        let p = factory.Parse(codeAndData)
        where p != null
        select p).FirstOrDefault();

由於您已經將FirstOrDefault與Comprehension語法混合在一起,因此您也可以這樣做:

return (from factory in factories
        select factory.Parse(codeAndData))
       .FirstOrDefault(p => p != null);

但這似乎是第一種選擇的愚蠢選擇。

除了使用分配,您還可以在執行選擇過程之前:

public static Function Parse(string codeAndData) {
    return (from factory in factories
            select factory.Parse(codeAndData)
            ).Where(y => y != null).FirstOrDefault();
}

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM