Force Linq to not delay execution

前端 未结 4 1987
礼貌的吻别
礼貌的吻别 2021-02-12 15:12

In fact, this is the same question as this post:

How can I make sure my LINQ queries execute when called in my DAL, not in a delayed fashion?

But since he didn\'

相关标签:
4条回答
  • 2021-02-12 15:46

    There is a LoadOptions property in the DataContext class that could help you fetch the data more eagerly.

    Else you could use a few clever placed ToList() 's.

    0 讨论(0)
  • 2021-02-12 15:54

    I know this thread is old... anyway, funny no-one mentioned .ToLast() yet. I'm doing something where linq is not much more than a glorified foreach driving some side effects where I don't really care about the query result... so I didn't want to allocate any more bogus memory than necessary.

    0 讨论(0)
  • 2021-02-12 16:02

    You wouldn't be boxing anything - you'd be buffering the results.

    Using ToList() is basically the way to go if you actually want the data. Unless you're ready to use the data immediately, it's got to be buffered somewhere, hasn't it? A list is just a convenient way to do that.

    The alternative is to do the processing then and there as well - use the data as you produce it, eagerly. I didn't quite follow the different threads side of thing, so it's not clear to me whether that would help you, but those are basically the choices available to you as far as I can see.

    This is actually somewhat explicit in your description:

    The design model up to this point is to send data-gathering threads off to find data, and when they're complete pass the data up for computation.

    Calling ToList() basically changes what you return from "a query which can fetch the data when asked to" to "the data itself, buffered in a list".

    0 讨论(0)
  • 2021-02-12 16:10

    Can you explain more why .ToList is not acceptable? You mentioned boxing and unboxing but those are completely unrelated topics.

    Part of forcing a LINQ query to complete on demand necessitates storing the results. Otherwise in order to see the results again, you'd have to repprocess the query. .ToList efficiently achieves this by storing the elements in a List<T>.

    It's possible to store the elements in virtually any other collection style data structure with various trade offs that may suit your needs better.

    0 讨论(0)
提交回复
热议问题