[.NET学习笔记] - Thread.Sleep与Task.Delay在生产中应用的性能测试

news2024/12/23 17:52:50

场景

有个Service类,自己在内部实现生产者/消费者模式。即多个指令输入该服务后对象后,Service内部有专门的消费线程执行传入的指令。每个指令的执行间隔为1秒。这里有两部分组成,

  1. 工作线程的载体。new ThreadTask.Run
  2. 执行等待的方法。Thread.SleepTask.Delay

测试环境

cpu: AMD 3700x 8核16线程
RAM:128G 3200MHz

示例代码

public class Service
{
    public Service(int id, Action f, int delayMillisecond = 1000)
    {
        Id = id;
        F = f;
        DelayMillisecond = delayMillisecond;
    }

    private int DelayMillisecond;
    private BlockingCollection<Action> _collection = new BlockingCollection<Action>();

    public int Id { get; }
    public Action F { get; }

    public void AddAction()
    {
        _collection.Add(F);
    }

    public void Run1()
    {
        new Thread(Worker_Sleep).Start();
    }

    public void Run2()
    {
        new Thread(Worker_Delay).Start();
    }

    public void Run3()
    {
        Task.Run(Worker_Sleep);
    }

    public void Run4()
    {
   		Task.Run(Worker_Delay);
    }

    private void Worker_Sleep()
    {
        {
            foreach (var action in _collection.GetConsumingEnumerable())
            {
                action?.Invoke();
                Thread.Sleep(DelayMillisecond);
            }
        }
    }

    private async void Worker_Delay()
    {
        {
            foreach (var action in _collection.GetConsumingEnumerable())
            {
                action?.Invoke();
                await Task.Delay(DelayMillisecond);
            }
        }
    }
}

使用BlockingCollection存储指令并通过GetConsumingEnumerable消费。

  • run1。Thread+Thread.Sleep
  • run2。Thread+Task.Delay
  • run3。Task.Run+Thread.Sleep
  • run4。Task.Run+Task.Delay
var serviceCount = 200; // 服务数量
var actionCount = 3; // 指令个数
var actionInterval = 1000; // 指令执行时间间隔ms
var services = new List<Service>();

Action f = () =>
{
	Console.WriteLine($"{DateTime.Now.ToString("HH:mm:ss ffff")}\t{Thread.CurrentThread.ManagedThreadId}\tCount:{Count}");
};

// 生成所有服务对象
for (int i = 0; i < serviceCount; i++)
{
    var s = new Service(i, f, actionInterval);
    services.Add(s);
}

Console.WriteLine($"{DateTime.Now.ToString("HH:mm:ss ffff")}\tRun");
services.ForEach(s => s.Run2());

while (true)
{
	// 输入任意内容,启动
    var msg = Console.ReadLine();

    Console.WriteLine($"{DateTime.Now.ToString("HH:mm:ss ffff")}\tStart!!!!!!!!!!");

	// 每个服务对象自行输入指令
    services.ForEach(s =>
    {
        for (int i = 0; i < actionCount; i++)
        {
            s.AddAction();
        }
    });
}

测试参数组为
serviceCount,50,100,200,500,1000。(其他使用默认)

类型对象个数指令个数间隔完成耗时
run150312.3s
run1100312.1s
run1200312.2s
run1500312.4s
run11000312.9s
run250312.3s
run2100312.5s
run2200313.1s
run2500315.2s
run210003110.5s
run3503127s
run31003178s
run320031-
run350031-
run3100031-
run450312.2s
run4100312.1s
run4200312.2s
run4500312.4s
run41000312.7s

3个指令,1秒间隔,理想状态下,完成耗时应是2秒。且随着对象个数增多,仍然能保持在一个合理范围。
由以上数据可知,run1run4是在时间消耗上比较符合期望。

  • run1。Thread+Thread.Sleep
  • run4。Task.Run+Task.Delay

我们更改参数,比较两者的cpu占用情况。测试参数如下:
服务数量:serviceCount=2000
指令个数:actionCount=50
指令执行时间间隔/ms:actionInterval = 1000
cpu占用情况如图。
在这里插入图片描述

服务数量:serviceCount=200
指令个数:actionCount=50
指令执行时间间隔/ms:actionInterval = 1000
cpu占用情况如图。
在这里插入图片描述
基于这两张图,可以得到初步结论:

  1. Task.Run+Task.Delay在初始化阶段需要占用较大的cpu资源。后续较为平稳,对数量的增加并不敏感(200到2000)
  2. Thread+Thread.Sleep在初始化期间与正常运行两个周期,前后一致性较强。但是对数量的增加敏感(200到2000)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/985431.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

大学生如何进行有效的时间管理?用待办清单APP高效管理个人时间

大学生的课外时间比较多&#xff0c;为了避免珍贵的时间被浪费&#xff0c;个人时间管理成为必不可少的技能。合理利用时间不仅能提高学习效率&#xff0c;还能充分发展自己的兴趣爱好和个人能力。那么&#xff0c;大学生如何实现有效的时间管理呢&#xff1f; 要实现有效的时…

GPT与BERT模型

NLP任务的核心逻辑是“猜概率”的游戏。BERT和GPT都是基于预训练语言模型的思想&#xff0c;通过大量语料训练得到语言模型。两种模型都是基于Transformer模型。 Bert 类似于Transformer的Encoder部分&#xff0c;GPT类似于Transformer的Decoder部分。两者最明显的在结构上的差…

【Matlab】Matlab实现数据的动态显示方法

Matlab实现数据的动态显示方法 主要为大家详细介绍了Matlab使用Plot函数实现数据动态显示方法&#xff0c;具有一定的参考价值&#xff0c;感兴趣的小伙伴们可 以参考一下 对于真实系统或者仿真平台&#xff0c;数据是增量式的产生的。Matlab除了强大的矩阵运算外&#xff0c;还…

PHP实践:用Yconf配置扩展为项目插上性能的翅膀

&#x1f3c6;作者简介&#xff0c;黑夜开发者&#xff0c;CSDN领军人物&#xff0c;全栈领域优质创作者✌&#xff0c;CSDN博客专家&#xff0c;阿里云社区专家博主&#xff0c;2023年6月CSDN上海赛道top4。 &#x1f3c6;数年电商行业从业经验&#xff0c;历任核心研发工程师…

发布自定义node包,实现自定义脚本命令

比方说yarn&#xff0c;cnpm&#xff0c;vite等命令&#xff0c;无需执行node xxxx&#xff0c;可以自定义执行并完成一些操作 创建一个文件夹如下 在index.js中输入 #!/usr/bin/env node console.log(hello world);在package.json中添加 {...,"bin": {"pack…

USB——硬件控制器分类(OHCI UHCI EHCI xHCI)))

文章目录 OHCIUHCIEHCIxHCIKHCI HCI&#xff1a;Host Controller Interface 主机控制器接口 OHCI、UHCI都是USB1.1的接口标准 EHCI是对应USB2.0的接口标准 xHCI是USB3.0的接口标准 OHCI 全称为 Open Host Controller Interface&#xff0c;这是一种 USB 控制器标准&#…

陇剑杯2023线上wp

1. hard_web hard_web_1 题目内容&#xff1a;服务器开放了哪些端口&#xff0c;请按照端口大小顺序提交答案&#xff0c;并以英文逗号隔开(如服务器开放了 80 81 82 83 端口&#xff0c;则答案为 80,81,82,83) 半开放扫描 端口开放状态 攻击机发送 SYN 请求连接此端口靶机…

八、Linux中的用户与文件权限

1、普通用户与特权用户 (1)在Linux中&#xff0c;和windows中一样。用户分为普通用户和特权用户。 特权用户&#xff1a;拥有系统管理的绝对权限。普通用户&#xff1a;普通用户的权限受到限制&#xff0c;只拥有基本的权限&#xff0c;某些操作没有权限。 (2)Linux中的特权…

瑞芯微RK3588开发板:虚拟机yolov5模型转化、开发板上python脚本调用npu并部署 全流程

目录 0. 背景1. 模型转化1.1 基础环境1.2 创建python环境1.3 将yolov5s.pt转为yolov5s.onnx1.4 将yolov5s.onnx转为yolov5s.rknn 2. 开发板部署2.1. c版本2.1. python版本&#xff08;必须是python 3.9&#xff09; 3. 性能测试 0. 背景 全面国产化&#xff0c;用瑞芯微rk3588…

YOLOV7改进-Soft-NMS(支持多种IoU变种选择)

soft-nmslink 1、复制到utils-general.py下 2、找到nms的代码&#xff0c;在它前面复制过来就行 3、在之前的nms模块下修改&#xff0c;注释 4、选择iou的地方&#xff0c;默认正常的 5、xxtrue即可 6、训练的时候开启&#xff0c;会增加训练成本 7、在test的时候用 8、密集…

IDEA版SSM入门到实战(Maven+MyBatis+Spring+SpringMVC) -Maven目录结构和idea的整合

Maven工程目录结构约束(约束>配置>代码) 项目名 src【书写源代码】 main【书写主程序代码】 java【书写java源代码】resources【书写配置文件代码】 test【书写测试代码】 java【书写测试代码】 pom.xml【书写Maven配置】 测试步骤&#xff08;进入项目名根目录【在根…

WMS仓储管理系统的功能与WCS系统有什么区别

在物流行业的现代化管理中&#xff0c;WMS仓储管理系统和WCS仓库控制系统是两个重要的组成部分。虽然它们都是用于仓库管理的软件系统&#xff0c;但是它们的功能和应用场景有很大的区别。本文我们将详细阐述这两者的功能和区别。 一、WMS仓储管理系统 WMS是一种软件系统&…

redux的理解

技术栈&#xff1a; react redux webpack react-router ES6/7/8 immutable 运行项目&#xff08;nodejs 6.0&#xff09; git clone https://github.com/bailicangdu/react-pxq.gitcd react-pxqnpm i 或者运行 yarn(推荐)npm startnpm run build &#xff08;发布&…

JavaSE(一)--Java语法。。。更新中。。。

&#xff01;&#xff01;&#xff01;本文适合有c和c基础的&#xff0c;通过比较c和java的不同&#xff0c;快速入门java。&#xff01;&#xff01;&#xff01; 这篇文章主要是介绍和c不同的地方&#xff0c;没说的知识点按照c写就行了。 零.整体的结构 Java是面向对象的程…

VGG 07

一、发展 1989年&#xff0c;Yann LeCun提出了一种用反向传导进行更新的卷积神经网络&#xff0c;称为LeNet。 1998年&#xff0c;Yann LeCun提出了一种用反向传导进行更新的卷积神经网络&#xff0c;称为LeNet-5 AlexNet是2012年ISLVRC 2012&#xff08;ImageNet Large Sca…

数据库分析工具explain

1.id:查询语句的编号 2.select_type:查询类型&#xff0c;有三种&#xff0c;simple简单查询&#xff0c;primary&#xff0c;subquery等 3.table:查询的表 4.type:查询性能&#xff0c;system > const > eq_ref > ref > range > index > ALL system&…

【EI会议征稿】第三届机械自动化与电子信息工程国际学术会议(MAEIE 2023)

第三届机械自动化与电子信息工程国际学术会议&#xff08;MAEIE 2023&#xff09; 第三届机械自动化与电子信息工程国际学术会议&#xff08;MAEIE 2023&#xff09;将于2023年12月15-17日在江苏南京举行。本会议通过与业内众多平台、社会各团体协力&#xff0c;聚集机械自动…

【亲测有效】申请wx.getLocation接口多次审核不通过解决方案,申请原因范文

背景&#xff1a;微信小程序申请wx.getLocation接口多次审核不通过 拒绝原因&#xff1a;你好&#xff0c;你的小程序“XXXX”申请的wx.getLocation接口因你提供的申请原因/辅助图片/网页/视频内容无法确认申请接口使用场景审核不通过&#xff0c;建议修改后重新提交。 经过多次…

数字化医院信息云平台源代码 HIS系统全套成品源代码

基层医疗云HIS作为基于云计算的B/S构架的HIS系统&#xff0c;为基层医疗机构提供了标准化的、信息化的、可共享的医疗信息管理系统&#xff0c;可有效进行医疗数据共享与交换&#xff0c;解决数据重复采集及信息孤岛等问题&#xff0c;实现对基层医疗数据的分析和挖掘&#xff…

使用ppyoloe训练voc数据集(自制的)详细教程

使用ppyoloe训练voc数据集&#xff08;自制的&#xff09;详细教程 一、数据集准备工作: Voc数据集的格式&#xff1a; 通过labelimg标注后的数据集如图所示 分别存放原图与xml标注文件 二、在ppdetection的工程下面找到dataset文件夹 其中有许多的参考数据的格式样例 在da…