欢迎来到代码驿站!

.NET代码

当前位置:首页 > 软件编程 > .NET代码

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

时间:2021-07-19 08:01:46|栏目:.NET代码|点击:

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

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》结果需要排序,因为并行线程的结果是乱序的

上一篇:重写、隐藏基类(new, override)的方法

栏    目:.NET代码

下一篇:C#编写SqlHelper类

本文标题:C#程序执行时间长查询速度慢解决方案

本文地址:http://www.codeinn.net/misctech/159303.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有