您好,
会员登录 快速注册
退出 ( 条未读消息)
关于本站 意见反馈 首页

公告:小宅博客网可以开发票了,需要发票的,去群里找群主哈!!
全部文章分类
  • 人工智能 >

  • 编程语言 >

  • WPF系列 >

  • ASP.NET系列 >

  • Linux >

  • 数据库 >

  • 嵌入式 >

  • WEB技术 >

  • PLC系列 >

  • 微服务与框架 >

  • 小宅DIY >

  • 学习资料 >

OpenCv基础 ANN车牌识别 yolov5车牌识别 指针式仪表识别 ROS系列 YOLO Halcon Detectron2 昇腾AI ChatGPT在线体验 英伟达JETSON ChatGLM ChatTTS FunASR 地平线 ByteTrack 魔搭社区 LangChain
C C# C++ Python Java Go
WPF
ASP.NET小功能 GPS定位系统-MVC GPS定位系统-VUE ASP.NET WebRTC
Linux Linux内核 Shell MakeFile
MySql SqlServer Oracle
STM8 STM32 51单片机
VUE入门 HTML JavaScript CSS layui镜像网站 ElementUi中文官网 element-plus 图标
三菱 欧姆龙 西门子 施耐德 松下 台达
IOTSharp IOTGateway ABP FRAMEWORK Docker
亚克力音响 编程仙途:智驭万法
面试题与技巧 Python入门技能树 微软C#教程
首页 编程之美 工具下载 全国就业 流量地图 文心一言
C#
内容简介 1、C#环境下使用EF操作MySql 2、实现串口通信 3、TCP通信 4、读写SqlServer数据库 5、读写ini配置文件 6、实现远程升级 7、调用打印机 8、AES数据加密与解密 AES加解密(RijndaelManaged版) 9、FTP的上传和下载 10、封装dll到exe 11、重写Button控件 12、重写Labeld控件 13、重写DataGridView控件 14、重写TabControl控件 15、重写ProgressBar控件 16、加载状态弹窗设计 17、模拟按键精灵 18、24种数据校验算法 19、C#如何调用opencv 20、地图上显示GPS坐标 21、使用EPPlus导出/导入xlsx格式的Excel报表和曲线图 22、exe程序生成安装包 23、DataGridView控件列控制 24、json解析 25、自定义委托事件 26、xml文件的生成与读取 27、DataGridView实现翻页效果 28、如何实现CAD dxf文件的读取 29、StopWatch的使用 30、Async与Await 同步与异步操作 31、关闭登录窗体打开主窗体的方法 32、SQLite数据库的操作 33、MD5数据加密 34、DES数据加密与解密 35、获取本地IP地址 36、打开与保存文件 37、静态图表显示(曲线图) 38、动态图表显示(曲线图) 39、根据公网IP获取地址信息 40、List转DataTable 41、C#下实现Ping操作 42、父窗体中嵌入子窗体 43、获取MySql数据库列表 44、WebSocket通讯 45、Mqtt客户端与服务端通讯 46、使用QRCode生成二维码 47、AForge调用摄像头 48、Emgu.CV调用摄像头 49、获取以太网网卡IP 50、DataGridView全选与定位 51、如何获取系统中所有程序的句柄 遍历指定目录下的所有文件 ​NPOI Excel报表的导入与导出 常用正则表达式字符串格式判断 Task和Thread的启停操作 C# 一些常用小功能1 C# 一些常用小功能2 如何使用C#来发送QQ邮件 Aspose.Slides文档格式转换 C# GDI+ 画心形 跳动动画 使用Remoting实现RPC RabbitMQ.消息发布与订阅 .Net Core 微信/支付宝 官方Demo C# OCR图片文字识别 Quartz 计划任务 文字语音播报 winform基于百度地图的电子围栏、路径规划、小车导航实现 Visual Studio C盘数据迁移,解决C盘空间不足的问题 Kafka通讯(Kafka-Net版) Kafka通讯(Confluent.Kafka版) 获取变量Description描述 C# 将PDF文档转换为Word文档 C# MVC 多图片上传预览
29、StopWatch的使用
31、关闭登录窗体打开主窗体的方法
激萌の小宅 bilibili C#

文章作者:激萌の小宅

促销:¥0

价格:¥0

配送方式: 购买后立即生效(如购买异常,请联系站长)
付款之后一定要等待自动跳转结束,否则购买可能会失败
  • 0 天

    有效期

  • 0

    总销量

  • 2

    累计评价

Async与Await 同步与异步操作 - (第三十讲)


转载的B站视频:


源码下载地址,提取码:sa4x

https://pan.baidu.com/s/109_JBTGTjUXVFS4cewEOuA 


关于Async与Await的详细介绍


一、什么是异步

       同步和异步主要用于修饰方法。当一个方法被调用时,调用者需要等待该方法执行完毕并返回才能继续执行,我们称这个方法是同步方法;当一个方法被调用时立即返回,并获取一个线程执行该方法内部的业务,调用者不用等待该方法执行完毕,我们称这个方法为异步方法。

       异步的好处在于非阻塞(调用线程不会暂停执行去等待子线程完成),因此我们把一些不需要立即使用结果、较耗时的任务设为异步执行,可以提高程序的运行效率。net4.0在ThreadPool的基础上推出了Task类,微软极力推荐使用Task来执行异步任务,现在C#类库中的异步方法基本都用到了Task;net5.0推出了async/await,让异步编程更为方便。本篇主要介绍Task、async/await相关的内容,其他异步操作的方式会在下一篇介绍。


二、Task介绍

        Task是在ThreadPool的基础上推出的,我们简单了解下ThreadPool。ThreadPool中有若干数量的线程,如果有任务需要处理时,会从线程池中获取一个空闲的线程来执行任务,任务执行完毕后线程不会销毁,而是被线程池回收以供后续任务使用。当线程池中所有的线程都在忙碌时,又有新任务要处理时,线程池才会新建一个线程来处理该任务,如果线程数量达到设置的最大值,任务会排队,等待其他任务释放线程后再执行。线程池能减少线程的创建,节省开销.


二、async/await介绍

        async/await是基于Task的,而Task是对ThreadPool的封装改进,主要是为了更有效的控制线程池中的线程(ThreadPool中的线程,我们很难通过代码控制其执行顺序,任务延续和取消等等);ThreadPool基于Thread的,主要目的是减少Thread创建数量和管理Thread的成本。async/await Task是C#中更先进的,也是微软大力推广的特性,我们在开发中可以尝试使用Task来替代Thread/ThreadPool,处理本地IO和网络IO任务是尽量使用async/await来提高任务执行效率。


Task异步执行,效果演示如下,执行总时间不变,大概是4秒左右。

Task异步执行的代码如下:

using System;
using System.Collections.Generic;
using System.Diagnostics;
using System.Net.Http;
using System.Threading.Tasks;
using System.Windows.Forms;

namespace WindowsFormsApp
{
    public partial class Form1 : Form
    {
        private readonly HttpClient httpClient = new HttpClient();

        public Form1()
        {
            InitializeComponent();
        }

        private void button1_Click(object sender, EventArgs e)
        {
            textBox1.Text = "";
            var stopwatch = Stopwatch.StartNew();
            DownloadWebsitesSync();
            textBox1.Text += $"Elapsed time: {stopwatch.Elapsed}{Environment.NewLine}";
        }
        private async void button2_Click(object sender, EventArgs e)
        {
            textBox1.Text = "";
            var stopwatch = Stopwatch.StartNew();
            await DownloadWebsitesAsync();
            textBox1.Text += $"Elapsed time: {stopwatch.Elapsed}{Environment.NewLine}";
        }
        private void ShowLog(string result)
        {
            textBox1.Text += result;
        }

        #region Button1
        private void DownloadWebsitesSync()
        {
            foreach (var site in Contents.WebSites)
            {
                var result = DownloadWebSiteSync(site);
                ShowLog(result);
            }
        }
        private string DownloadWebSiteSync(string url)
        {
            var response = httpClient.GetAsync(url).GetAwaiter().GetResult();
            var responsePayloadBytes = response.Content.ReadAsByteArrayAsync().GetAwaiter().GetResult();
            return $"Finish downloding data from {url}. Total bytes returned {responsePayloadBytes.Length}. {Environment.NewLine}";
        }
        #endregion

        #region Button2
        private async Task DownloadWebsitesAsync()
        {
            foreach (var site in Contents.WebSites)
            {
                var result = await Task.Run(() => DownloadWebSiteSync(site));
                ShowLog(result);
            }
        }
        #endregion
    }
}


异步+并行下载的执行效果如下,下载速度提升到了2秒左右,但是启动时第一次耗时还是很大。

异步+并行的代码如下:

using System;
using System.Collections.Generic;
using System.Diagnostics;
using System.Net.Http;
using System.Threading.Tasks;
using System.Windows.Forms;

namespace WindowsFormsApp
{
    public partial class Form1 : Form
    {
        private readonly HttpClient httpClient = new HttpClient();

        public Form1()
        {
            InitializeComponent();
        }

        private void button1_Click(object sender, EventArgs e)
        {
            textBox1.Text = "";
            var stopwatch = Stopwatch.StartNew();
            DownloadWebsitesSync();
            textBox1.Text += $"Elapsed time: {stopwatch.Elapsed}{Environment.NewLine}";
        }
        private async void button2_Click(object sender, EventArgs e)
        {
            textBox1.Text = "";
            var stopwatch = Stopwatch.StartNew();
            await DownloadWebsitesAsync();
            textBox1.Text += $"Elapsed time: {stopwatch.Elapsed}{Environment.NewLine}";
        }
        private void ShowLog(string result)
        {
            textBox1.Text += result;
        }

        #region Button1
        private void DownloadWebsitesSync()
        {
            foreach (var site in Contents.WebSites)
            {
                var result = DownloadWebSiteSync(site);
                ShowLog(result);
            }
        }
        private string DownloadWebSiteSync(string url)
        {
            var response = httpClient.GetAsync(url).GetAwaiter().GetResult();
            var responsePayloadBytes = response.Content.ReadAsByteArrayAsync().GetAwaiter().GetResult();
            return $"Finish downloding data from {url}. Total bytes returned {responsePayloadBytes.Length}. {Environment.NewLine}";
        }
        #endregion

        #region Button2
        private async Task DownloadWebsitesAsync()
        {
            // 主要修改点
            List<Task<string>> downloadwebTasks = new List<Task<string>>();
            foreach (var site in Contents.WebSites)
            {
                downloadwebTasks.Add(Task.Run(() => DownloadWebSiteSync(site)));
            }
            var res = await Task.WhenAll(downloadwebTasks);
            foreach(var r in res)
            {
                ShowLog(r);
            }
        }
        #endregion
    }
}


进一步优化,解决程序冷启动时的不稳定现象,效果如下:

进一步优化后的代码如下:

#region Button2
private async Task DownloadWebsitesAsync()
{
    List<Task<string>> downloadwebTasks = new List<Task<string>>();
    foreach (var site in Contents.WebSites)
    {
        // 修改这个
        downloadwebTasks.Add(DownloadWebSiteSync2(site));
    }
    var res = await Task.WhenAll(downloadwebTasks);
    foreach(var r in res)
    {
        ShowLog(r);
    }
}

// 进一步优化,添加这个代码
private async Task<string> DownloadWebSiteSync2(string url)
{
    var response = await httpClient.GetAsync(url);
    var responsePayloadBytes = await response.Content.ReadAsByteArrayAsync();
    return $"Finish downloding data from {url}. Total bytes returned {responsePayloadBytes.Length}. {Environment.NewLine}";
}
#endregion


29、StopWatch的使用
31、关闭登录窗体打开主窗体的方法

友情链接: CSDN激萌の小宅 95知识库 自考题库 罗分明个人网络博客 精益编程leanboot

小宅博客  www.bilibili996.com All Rights Reserved. 备案号: 闽ICP备2024034575号

网站经营许可证  福建省福州市 Copyright©2021-2025 版权所有

小宅博客
首页 智能家居 地图定位
公告:小宅博客网可以开发票了,需要发票的,去群里找群主哈!!

文章作者:激萌の小宅

促销:¥0

价格:¥0

配送方式: 购买后立即生效(如购买异常,请联系站长)
付款之后一定要等待自动跳转结束,否则购买可能会失败
  • 0 天

    有效期

  • 0

    总销量

  • 2

    累计评价

Async与Await 同步与异步操作 - (第三十讲)


转载的B站视频:


源码下载地址,提取码:sa4x

https://pan.baidu.com/s/109_JBTGTjUXVFS4cewEOuA 


关于Async与Await的详细介绍


一、什么是异步

       同步和异步主要用于修饰方法。当一个方法被调用时,调用者需要等待该方法执行完毕并返回才能继续执行,我们称这个方法是同步方法;当一个方法被调用时立即返回,并获取一个线程执行该方法内部的业务,调用者不用等待该方法执行完毕,我们称这个方法为异步方法。

       异步的好处在于非阻塞(调用线程不会暂停执行去等待子线程完成),因此我们把一些不需要立即使用结果、较耗时的任务设为异步执行,可以提高程序的运行效率。net4.0在ThreadPool的基础上推出了Task类,微软极力推荐使用Task来执行异步任务,现在C#类库中的异步方法基本都用到了Task;net5.0推出了async/await,让异步编程更为方便。本篇主要介绍Task、async/await相关的内容,其他异步操作的方式会在下一篇介绍。


二、Task介绍

        Task是在ThreadPool的基础上推出的,我们简单了解下ThreadPool。ThreadPool中有若干数量的线程,如果有任务需要处理时,会从线程池中获取一个空闲的线程来执行任务,任务执行完毕后线程不会销毁,而是被线程池回收以供后续任务使用。当线程池中所有的线程都在忙碌时,又有新任务要处理时,线程池才会新建一个线程来处理该任务,如果线程数量达到设置的最大值,任务会排队,等待其他任务释放线程后再执行。线程池能减少线程的创建,节省开销.


二、async/await介绍

        async/await是基于Task的,而Task是对ThreadPool的封装改进,主要是为了更有效的控制线程池中的线程(ThreadPool中的线程,我们很难通过代码控制其执行顺序,任务延续和取消等等);ThreadPool基于Thread的,主要目的是减少Thread创建数量和管理Thread的成本。async/await Task是C#中更先进的,也是微软大力推广的特性,我们在开发中可以尝试使用Task来替代Thread/ThreadPool,处理本地IO和网络IO任务是尽量使用async/await来提高任务执行效率。


Task异步执行,效果演示如下,执行总时间不变,大概是4秒左右。

Task异步执行的代码如下:

using System;
using System.Collections.Generic;
using System.Diagnostics;
using System.Net.Http;
using System.Threading.Tasks;
using System.Windows.Forms;

namespace WindowsFormsApp
{
    public partial class Form1 : Form
    {
        private readonly HttpClient httpClient = new HttpClient();

        public Form1()
        {
            InitializeComponent();
        }

        private void button1_Click(object sender, EventArgs e)
        {
            textBox1.Text = "";
            var stopwatch = Stopwatch.StartNew();
            DownloadWebsitesSync();
            textBox1.Text += $"Elapsed time: {stopwatch.Elapsed}{Environment.NewLine}";
        }
        private async void button2_Click(object sender, EventArgs e)
        {
            textBox1.Text = "";
            var stopwatch = Stopwatch.StartNew();
            await DownloadWebsitesAsync();
            textBox1.Text += $"Elapsed time: {stopwatch.Elapsed}{Environment.NewLine}";
        }
        private void ShowLog(string result)
        {
            textBox1.Text += result;
        }

        #region Button1
        private void DownloadWebsitesSync()
        {
            foreach (var site in Contents.WebSites)
            {
                var result = DownloadWebSiteSync(site);
                ShowLog(result);
            }
        }
        private string DownloadWebSiteSync(string url)
        {
            var response = httpClient.GetAsync(url).GetAwaiter().GetResult();
            var responsePayloadBytes = response.Content.ReadAsByteArrayAsync().GetAwaiter().GetResult();
            return $"Finish downloding data from {url}. Total bytes returned {responsePayloadBytes.Length}. {Environment.NewLine}";
        }
        #endregion

        #region Button2
        private async Task DownloadWebsitesAsync()
        {
            foreach (var site in Contents.WebSites)
            {
                var result = await Task.Run(() => DownloadWebSiteSync(site));
                ShowLog(result);
            }
        }
        #endregion
    }
}


异步+并行下载的执行效果如下,下载速度提升到了2秒左右,但是启动时第一次耗时还是很大。

异步+并行的代码如下:

using System;
using System.Collections.Generic;
using System.Diagnostics;
using System.Net.Http;
using System.Threading.Tasks;
using System.Windows.Forms;

namespace WindowsFormsApp
{
    public partial class Form1 : Form
    {
        private readonly HttpClient httpClient = new HttpClient();

        public Form1()
        {
            InitializeComponent();
        }

        private void button1_Click(object sender, EventArgs e)
        {
            textBox1.Text = "";
            var stopwatch = Stopwatch.StartNew();
            DownloadWebsitesSync();
            textBox1.Text += $"Elapsed time: {stopwatch.Elapsed}{Environment.NewLine}";
        }
        private async void button2_Click(object sender, EventArgs e)
        {
            textBox1.Text = "";
            var stopwatch = Stopwatch.StartNew();
            await DownloadWebsitesAsync();
            textBox1.Text += $"Elapsed time: {stopwatch.Elapsed}{Environment.NewLine}";
        }
        private void ShowLog(string result)
        {
            textBox1.Text += result;
        }

        #region Button1
        private void DownloadWebsitesSync()
        {
            foreach (var site in Contents.WebSites)
            {
                var result = DownloadWebSiteSync(site);
                ShowLog(result);
            }
        }
        private string DownloadWebSiteSync(string url)
        {
            var response = httpClient.GetAsync(url).GetAwaiter().GetResult();
            var responsePayloadBytes = response.Content.ReadAsByteArrayAsync().GetAwaiter().GetResult();
            return $"Finish downloding data from {url}. Total bytes returned {responsePayloadBytes.Length}. {Environment.NewLine}";
        }
        #endregion

        #region Button2
        private async Task DownloadWebsitesAsync()
        {
            // 主要修改点
            List<Task<string>> downloadwebTasks = new List<Task<string>>();
            foreach (var site in Contents.WebSites)
            {
                downloadwebTasks.Add(Task.Run(() => DownloadWebSiteSync(site)));
            }
            var res = await Task.WhenAll(downloadwebTasks);
            foreach(var r in res)
            {
                ShowLog(r);
            }
        }
        #endregion
    }
}


进一步优化,解决程序冷启动时的不稳定现象,效果如下:

进一步优化后的代码如下:

#region Button2
private async Task DownloadWebsitesAsync()
{
    List<Task<string>> downloadwebTasks = new List<Task<string>>();
    foreach (var site in Contents.WebSites)
    {
        // 修改这个
        downloadwebTasks.Add(DownloadWebSiteSync2(site));
    }
    var res = await Task.WhenAll(downloadwebTasks);
    foreach(var r in res)
    {
        ShowLog(r);
    }
}

// 进一步优化,添加这个代码
private async Task<string> DownloadWebSiteSync2(string url)
{
    var response = await httpClient.GetAsync(url);
    var responsePayloadBytes = await response.Content.ReadAsByteArrayAsync();
    return $"Finish downloding data from {url}. Total bytes returned {responsePayloadBytes.Length}. {Environment.NewLine}";
}
#endregion