C#程序执行时间长查询速度慢解决方案

 更新时间:2020年07月13日 09:57:57   作者:叶丶梓轩  
这篇文章主要介绍了C#程序执行时间长查询速度慢解决方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

一,程序执行慢导致的原因就是查询数据库慢.,导致返回值慢,那这个要怎么解决呢?

1,优化数据库查询如这个文章 C#导出数据到excel如何提升性能

2,使用线程并行查询,然后合并成一个集合,代码如下,必须留意备注的核心点

using System;
using System.Collections.Generic;
using System.Diagnostics;
using System.Linq;
using System.Threading;
using System.Threading.Tasks;

namespace TestConsoleApp
{
  /// <summary>
  ///C#慢查询解决: 线程并行实现处理
  /// </summary>
  class Program
  {
    static void Main(string[] args)
    {
      List<Task> taskList = new List<Task>();
      int count = 100;
      int batch = count % 10;
      object lockObj = new object();
      List<int> list = new List<int>();

      ///开启线程并行执行
      Stopwatch stopwatch = new Stopwatch();
      stopwatch.Start();
      for (int i = 0; i < batch; i++)
      {
        taskList.Add(Task.Run(() =>
        {
          for (int j = count * i; j < count * (i + 1); j++)
          {
            ///休眠等待,模拟慢查询需要消耗的时间
            Thread.Sleep(100);
            ///核心逻辑:避免线程插入冲突
            lock (lockObj)
            {
              list.Add(i);
            }
          }
        }));
      }
      ///这里核心是等待所有的线程结束,然后再执行下去
      Task.WaitAll(taskList.ToArray());
      ///这里再内存处理排序,避免返回的结果跟正常查询出来的结果排序不一致
      list = list.OrderByDescending(u => u).ToList();
      Console.WriteLine(stopwatch.ElapsedMilliseconds);


      Console.WriteLine("**********分割线***********");

      ///原始遍历实现
      List<int> list2 = new List<int>();
      Stopwatch stopwatch2 = new Stopwatch();
      stopwatch2.Start();
      for (int i = 0; i < count; i++)
      {
        ///休眠等待,模拟慢查询需要消耗的时间
        Thread.Sleep(100);
        list2.Add(i);
      }
      Console.WriteLine(stopwatch2.ElapsedMilliseconds);
      Console.ReadLine();
    }
  }
}

PS:核心点

1》线程等待线程结束Task.WaitAll

2》锁住集合,以防插入占用导致报错

3》结果需要排序,因为并行线程的结果是乱序的

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • C# Winform实现波浪滚动效果

    C# Winform实现波浪滚动效果

    这篇文章主要为大家详细介绍了C# Winform实现波浪滚动效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-11-11
  • Unity实现相机截图功能

    Unity实现相机截图功能

    这篇文章主要为大家详细介绍了Unity实现相机截图功能,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-04-04
  • C# WPF ListBox 动态显示图片功能

    C# WPF ListBox 动态显示图片功能

    这篇文章主要介绍了C# WPF ListBox 动态显示图片,处理过程分为前台代码和后台代码,本文结合实例代码给大家介绍的非常详细,需要的朋友可以参考下
    2023-08-08
  • C# winForm自定义弹出页面效果

    C# winForm自定义弹出页面效果

    这篇文章主要为大家详细介绍了C# winForm自定义弹出页面效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-02-02
  • C#使用文件流读取文件的方法

    C#使用文件流读取文件的方法

    这篇文章主要介绍了C#使用文件流读取文件的方法,涉及C#中FileInfo类操作文件的技巧,需要的朋友可以参考下
    2015-04-04
  • C#实现嵌套循环的示例代码

    C#实现嵌套循环的示例代码

    这篇文章主要为大家详细介绍了C#实现嵌套循环的相关知识,文中的示例代码讲解详细,具有一定的学习价值,感兴趣的小伙伴可以跟随小编一起学习一下
    2023-09-09
  • 详解C#如何计算一个实例占用多少内存

    详解C#如何计算一个实例占用多少内存

    我们都知道CPU和内存是程序最为重要的两类指标,那么有多少人真正想过一个类型的实例在内存中究竟占多少字节,本文就来用C#计算一下一个实例占用多少内存吧
    2023-06-06
  • unity通过Mesh网格绘制图形(三角形、正方体、圆柱)

    unity通过Mesh网格绘制图形(三角形、正方体、圆柱)

    这篇文章主要为大家详细介绍了unity通过Mesh网格绘制图形:三角形、正方体、圆柱,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-11-11
  • C# winForm实现的气泡提示窗口功能示例

    C# winForm实现的气泡提示窗口功能示例

    这篇文章主要介绍了C# winForm实现的气泡提示窗口功能,涉及C# winForm窗口属性与设置相关操作技巧,需要的朋友可以参考下
    2018-03-03
  • 解决WPF绘制矢量图形模糊的问题

    解决WPF绘制矢量图形模糊的问题

    这篇文章介绍了WPF绘制矢量图形模糊问题的解决方法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-06-06

最新评论