我的编程空间,编程开发者的网络收藏夹
学习永远不晚

C# Linq延迟查询的执行实例代码

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

C# Linq延迟查询的执行实例代码

C# Linq延迟查询

在定义linq查询表达式时,查询是不会执行,查询会在迭代数据项时运行。它使用yield return 语句返回谓词为true的元素。


var names = new List<string> { "Nino", "Alberto", "Juan", "Mike", "Phil" };
var namesWithJ = from n in names
                 where n.StartsWith("J")
                 orderby n
                 select n;
Console.WriteLine("First iteration");
foreach (string name in namesWithJ) 
{
    Console.WriteLine(name);
}
Console.WriteLine();

names.Add("John");
names.Add("Jim");
names.Add("Jack");
names.Add("Denny");

Console.WriteLine("Second iteration");
foreach (string name in namesWithJ)
{
    Console.WriteLine(name);
}

运行结果为

First iteration
Juan

Second iteration
Jack
Jim
John
Juan

从执行结果可以看出,当在定义namesWithJ时并不会执行,而是在执行每个foreach语句时进行,所以后面增加的“John”、“Jim”、“Jack”和“Denny”在第二次迭代时也会参与进来。

ToArray()、ToList()等方法可以改变这个操作,把namesWithJ的定义语句修改为


var namesWithJ = (from n in names
                  where n.StartsWith("J")
                  orderby n
                  select n).ToList();

运行结果为

First iteration
Juan

Second iteration
Juan

在日常工作中,我们常会使用 datas.Where(x=>x.XX == XXX).FirstOrDefault() 和 datas.FirstOrDefault(x=>x.XX == XXX),其实这两种写法性能是等效的,如果真的要在性能上分个高低,请见下面

C# Linq.FirstOrDefault、Linq.Where、Linq.AsParallel、List.Exists、List.Find、Dictionar.TryGetValue、HashSet.Contains 性能的比较

今天我们来比较一下集合检索方法性能更优问题,测试代码


public class Entity
{
    public int Id { get; set; }
    public int No { get; set; }
    public string Col1 { get; set; }
    public string Col2 { get; set; }
    public string Col3 { get; set; }
    public string Col4 { get; set; }
    public string Col5 { get; set; }
    public string Col6 { get; set; }
    public string Col7 { get; set; }
    public string Col8 { get; set; }
    public string Col9 { get; set; }
    public string Col10 { get; set; }
}
static void TestFindVelocity(int totalDataCount, int executeCount)
{
    #region 构造数据
    List<Entity> datas = new List<Entity>();
    for (int i = 0; i < totalDataCount; i++)
    {
        var item = new Entity
        {
            No = i + 1,
            Col1 = Guid.NewGuid().ToString("N"),
            Col2 = Guid.NewGuid().ToString("N"),
            Col3 = Guid.NewGuid().ToString("N"),
            Col4 = Guid.NewGuid().ToString("N"),
            Col5 = Guid.NewGuid().ToString("N"),
            Col6 = Guid.NewGuid().ToString("N"),
            Col7 = Guid.NewGuid().ToString("N"),
            Col8 = Guid.NewGuid().ToString("N"),
            Col9 = Guid.NewGuid().ToString("N"),
            Col10 = Guid.NewGuid().ToString("N"),
        };
        datas.Add(item);
    }
    #endregion
    var dicDatas = datas.ToDictionary(x => x.No);
    var hashSetDatas = datas.ConvertAll<Tuple<int, int>>(x => new Tuple<int, int>(x.No, x.No + 1000)).ToHashSet();
    Stopwatch sw = new Stopwatch();
    Random random = new Random();
    Entity searchResult = null;
    bool searchResultBool = false;
    // 每次查询索引
    List<int> indexs = Enumerable.Range(1, executeCount).Select(x => random.Next(1, totalDataCount)).ToList();

    sw.Start();
    for (int i = 0; i < executeCount; i++)
    {
        searchResult = datas.FirstOrDefault(x => x.No == indexs[i]);
    }
    sw.Stop();
    Console.WriteLine($"list FirstOrDefault 耗时:{sw.ElapsedMilliseconds}");

    sw.Restart();
    for (int i = 0; i < executeCount; i++)
    {
        searchResult = datas.Where(x => x.No == indexs[i]).First();
    }
    sw.Stop();
    Console.WriteLine($"list Where+First 耗时:{sw.ElapsedMilliseconds}");

    sw.Restart();
    for (int i = 0; i < executeCount; i++)
    {
        searchResultBool = datas.Exists(x => x.No == indexs[i]);
    }
    sw.Stop();
    Console.WriteLine($"list Exist 耗时:{sw.ElapsedMilliseconds}");

    sw.Restart();
    for (int i = 0; i < executeCount; i++)
    {
        searchResult = datas.Find(x => x.No == indexs[i]);
    }
    sw.Stop();
    Console.WriteLine($"list Find 耗时:{sw.ElapsedMilliseconds}");

    sw.Restart();
    for (int i = 0; i < executeCount; i++)
    {
        dicDatas.TryGetValue(indexs[i], out searchResult);
    }
    sw.Stop();
    Console.WriteLine($"dictionary TryGetValue 耗时:{sw.ElapsedMilliseconds}");

    sw.Restart();
    for (int i = 0; i < executeCount; i++)
    {
        searchResultBool = hashSetDatas.Contains(new Tuple<int, int>(indexs[i], indexs[i] + 1000));
    }
    sw.Stop();
    Console.WriteLine($"Hashset contains 耗时:{sw.ElapsedMilliseconds}");
}

结果

(集合数量,测试次数) Linq.FirstOrDefault Linq.Where+First List.Exists List.Find Dictionary.TryGetValue HashSet.Contains

(100, 5000000)

4544 3521 1992 1872 66 924

(1000, 5000000)

41751 29417 20631 19490 70 869

(10000, 5000000)

466918 397425 276409 281647 85 946

(50000, 5000)

6292 4602 4252 3559 0 2

(500000, 5000)

56988 55568 48423 48395 1 5

应避免错误写法是 datas.Where(x=>x.XX == XXX).ToList()[0]

总结

到此这篇关于C# Linq延迟查询的执行的文章就介绍到这了,更多相关C# Linq延迟查询内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

C# Linq延迟查询的执行实例代码

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

LINQ如何实现子查询和延迟执行编程

这篇文章将为大家详细讲解有关LINQ如何实现子查询和延迟执行编程,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。LINQ子查询 LINQ子查询是一个包含了另外一个查询的Lambda表达式的查询. 以下的例子
2023-06-17

C语言如何延迟代码执行若干秒

本文介绍了在C语言中延迟代码执行若干秒的四种方法:sleep()、usleep()、nanosleep()和select()函数。sleep()完全阻塞进程,而usleep()、nanosleep()和select()非阻塞,允许在暂停期间处理其他任务。所选方法取决于所需的精确度和阻塞行为。
C语言如何延迟代码执行若干秒
2024-04-02

C语言如何延迟代码执行若干微秒

本文介绍了在C语言中延迟代码执行若干微秒的四种方法:usleep()函数:休眠指定微秒数。nanosleep()函数:休眠指定纳秒数。clock_nanosleep()函数:类似于nanosleep(),但使用不同的时钟ID。busy-wait循环:通过循环等待的方式实现延迟,精度高但消耗CPU资源。选择合适的方法取决于精度要求、资源消耗、延迟时间和平台兼容性等因素。
C语言如何延迟代码执行若干微秒
2024-04-02

C语言如何延迟代码执行直到指定的时间

这篇文章介绍了如何在C语言中延迟代码执行,提供了三种方法:sleep()函数用于暂停指定秒数,nanosleep()函数用于以纳秒为单位精确暂停,usleep()函数用于暂停指定微秒数。选择合适的方法取决于所需的精度级别。
C语言如何延迟代码执行直到指定的时间
2024-04-02

C语言如何延迟代码执行若干秒和纳秒

本文提供了C语言中延迟代码执行的解决方案,包括使用sleep、nanosleep和usleep函数。sleep用于延迟秒级,nanosleep用于延迟纳秒级,usleep用于延迟微秒级。选择合适的函数取决于所需的精度、可移植性和阻塞性。需要注意的是,实际延迟时间可能与指定时间略有不同,并且精确的延迟通常是不必要的,除非在非常特定的应用中。
C语言如何延迟代码执行若干秒和纳秒
2024-04-02

PHP如何延迟代码执行直到指定的时间

PHP提供多种延迟代码执行的方法:sleep()函数:休眠指定秒数。usleep()函数:休眠指定微秒数。now()和strtotime()函数:计算延迟时间。TaskScheduler:安排任务在指定时间执行。exec()函数:结合sleep命令执行延迟操作。pcntl_fork()和pcntl_waitpid()函数:在子进程中延迟执行。curl_multi()函数:结合CURLOPT_TIMEOUT_MS选项限制执行时间。选择方法取决于延迟要求和复杂程度。
PHP如何延迟代码执行直到指定的时间
2024-04-02

Java如何延迟代码执行直到指定的时间

本文介绍了Java延迟代码执行的五种机制:Thread.sleep():阻塞线程指定时间。ScheduledExecutorService:安排任务在特定时间或周期性执行。ScheduledFuture:表示计划的任务,可检索结果或取消任务。DelayQueue:阻塞队列,元素按延迟值排序。Timer:安排任务在特定时间或周期性执行。选择合适的机制取决于延迟性质和精确度要求。
Java如何延迟代码执行直到指定的时间
2024-04-02

Python如何延迟代码执行直到指定的时间

本文介绍了Python延迟代码执行的多种技术,包括time模块的sleep()函数、threading模块的Timer类、sched模块的scheduler类、asyncio模块以及第三方库schedule。选择合适的方法取决于应用程序的需求,对于简单任务,time.sleep()函数足以胜任,而对于更复杂的任务,则需要更高级的方法如threading.Timer或sched.scheduler。
Python如何延迟代码执行直到指定的时间
2024-04-02

SpringBoot实现redis延迟队列的示例代码

本篇文章介绍了SpringBoot实现Redis延迟队列的示例代码,采用了zset有序集合和list类型。入队任务时设置时间戳score,时间戳到达时任务从zset弹出执行,同时从list中移除。定时任务定时执行任务和移除过期任务,保证队列的正常运作。需要注意redisTemplate的连接池配置、定时任务执行间隔、过期任务清理策略等细节。
SpringBoot实现redis延迟队列的示例代码
2024-04-02

Go语言如何延迟代码执行直到指定的时间

在Go语言中,可以通过time包的函数延迟代码执行。time.Sleep()可暂停当前协程;time.After()返回一个在指定时间后发送值的channel;time.AfterFunc()在延迟后执行一个指定函数;time.NewTicker()则创建定期发送值的ticker。选择合适的函数取决于应用程序的具体需求。
Go语言如何延迟代码执行直到指定的时间
2024-04-02

百行代码实现基于Redis的可靠延迟队列

目录原理详解pending2ReadyScriptready2UnackScriptunack2RetryScriptackconsume在之前探讨延时队列的文章中我们提到了 redisson delayqueue 使用 redis 的有序
2022-06-23

MyBatis特殊SQL的执行实例代码

这篇文章主要给大家介绍了关于MyBatis特殊SQL执行的相关资料,文中通过实例代码和图文介绍的非常详细,对大家学习或者使用MyBatis具有一定的参考学习价值,需要的朋友可以参考下
2023-01-30

laravel的执行流程实例代码分析

这篇文章主要讲解了“laravel的执行流程实例代码分析”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“laravel的执行流程实例代码分析”吧!1.index.php$app = requi
2023-07-04

Mybatis查询记录条数的实例代码

这几天在学SSM框架,今天在SSM框架中根据某个条件查询MySQL数据库中的记录条数,碰到一些问题,记录一下User.xml