C#使用“分块处理”和“并行处理”优化代码

模拟处理10万条List集合中的数据,

List<PeoMterModel> peoMterModels = new List<PeoMterModel>();
for (int i = 0; i < 100000; i++) 
{
    PeoMterModel peoMterModel=new PeoMterModel();
    peoMterModel.Id=Guid.Empty;
    peoMterModel.Name= i.ToString();
    peoMterModels.Add(peoMterModel);
}

设置每次处理20000条,判断需要多少个线程,用线程并行处理处理数据。每次处理2000条,则需要5个线程进行处理,计算需要设置多少个线程

int batchSize = 20000;
int numberOfTasks = (int)Math.Ceiling((double)peoMterModels.Count / batchSize);

用Task集合进行处理这些数据

var tasks = new List<Task>();
Stopwatch stopwatch = new Stopwatch();
stopwatch.Start();
for (int i = 0; i < numberOfTasks; i++)
{
    int start = i * batchSize;
    int end = Math.Min(start + batchSize, peoMterModels.Count);
    var batch = peoMterModels.GetRan
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值