4

我有一个类似于以下的 linq 语句:

        var entities = from row in table.AsEnumerable()
                                    select new
                                    {
                                        ID = row.ID,
                                        X = GetObjectByProcessingID(row.ID)[0],
                                        Y = GetObjectByProcessingID(row.ID)[1],
                                        ....
                                    };

是否可以执行以下操作:

        var entities = from row in table.AsEnumerable()
                                    select new
                                    {
                                        private var tmp = GetObjectByProcessingID(row.ID),
                                        ID = row.ID,
                                        X = tmp[0],
                                        Y = tmp[1],
                                        ....
                                    };

避免调用 GetObjectByProcessingID 两次?

我知道您可以执行以下操作:

        var entities = from row in table.AsEnumerable()
                                    select new
                                    {
                                        ID = row.ID,
                                        XAndY = GetObjectByProcessingID(row.ID),
                                        ....
                                    };

但在这种情况下,它将暴露整个数组。我也知道我可以在方法端实现缓存(GetObjectByProcessingID)或创建一个辅助方法来调用它并记住最后一个值(如果 ID 相同)。但是有更好的方法吗?我可以在创建匿名类型时创建临时变量吗?

4

1 回答 1

11

使用这样的let关键字:

var entities = from row in table.AsEnumerable()
               let tmp = GetObjectByProcessingID(row.ID)
               select new {
                            ID = row.ID,
                            X = tmp[0],
                            Y = tmp[1],
                            ....
                           };

您也可以尝试使用method syntax我最喜欢的:

var entities = table.AsEnumerable()
                    .Select(row => {
                       var tmp = GetObjectByProcessingID(row.ID);
                       return new {
                                ID = row.ID,
                                X = tmp[0],
                                Y = tmp[1],
                                ....
                              };
                     });
于 2013-10-22T15:05:39.473 回答