C#使用Task实现并行编程

 更新时间:2022年08月27日 15:10:40   作者:taadis  
这篇文章介绍了C#使用Task实现并行编程的方法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

故事背景

透着纱的窗外的阳光, 又是一个星期一.

慢慢来

一看时间, 还早, 那么蹦跶起来

  • 穿衣
  • 刷牙
  • 洗脸

用代码来说的话, 应该是这样:

// Program.cs
using System;
using System.Diagnostics;
using System.Threading;

namespace ConsoleApp1
{
    class Program
    {
        static void Main(string[] args)
        {
            Console.WriteLine("早起三件事开始...");
            Stopwatch sw = new Stopwatch();
            sw.Start();
            Dress();
            BrushTeeth();
            WashFace();
            sw.Stop();
            Console.WriteLine($"...早起三件事完成, 总耗时 {sw.Elapsed.Seconds} 秒");
            Console.ReadKey();
        }

        /// <summary>
        /// 穿衣
        /// </summary>
        static void Dress()
        {
            Console.WriteLine($"穿衣开始...");
            Stopwatch sw = new Stopwatch();
            sw.Start();
            Thread.Sleep(timeout: TimeSpan.FromSeconds(value: 1));
            sw.Stop();
            Console.WriteLine($"...穿衣完成, 耗时 {sw.Elapsed.Seconds} 秒");
        }

        /// <summary>
        /// 刷牙
        /// </summary>
        static void BrushTeeth()
        {
            Console.WriteLine($"刷牙开始...");
            Stopwatch sw = new Stopwatch();
            sw.Start();
            Thread.Sleep(timeout: TimeSpan.FromSeconds(value: 3));
            sw.Stop();
            Console.WriteLine($"...刷牙完成, 耗时 {sw.Elapsed.Seconds} 秒");
        }

        /// <summary>
        /// 洗脸
        /// </summary>
        static void WashFace()
        {
            Console.WriteLine($"洗脸开始...");
            Stopwatch sw = new Stopwatch();
            sw.Start();
            Thread.Sleep(timeout: TimeSpan.FromSeconds(value: 5));
            sw.Stop();
            Console.WriteLine($"...系列完成, 耗时 {sw.Elapsed.Seconds} 秒");
        }
    }
}

运行之后, 等待一会, 会看到如下输出:

早起三件事开始...
穿衣开始...
...穿衣完成, 耗时 1 秒
刷牙开始...
...刷牙完成, 耗时 3 秒
洗脸开始...
...系列完成, 耗时 5 秒
...早起三件事完成, 总耗时 9 秒

一件一件事慢慢来, 总耗时 9 秒...

赶时间

一看时间, 哎呦我去, 快迟到了, 穿衣 & 刷牙 & 洗脸一起来吧...别问我现实中怎么实现的

总而言之代码是这样滴:

// Program.cs
using System;
using System.Diagnostics;
using System.Threading;
using System.Threading.Tasks;

namespace ConsoleApp1
{
    class Program
    {
        static void Main(string[] args)
        {
            Console.WriteLine("早起三件事开始...");
            Stopwatch sw = new Stopwatch();
            sw.Start();
            Task dressTask = Task.Factory.StartNew(action: Dress);
            Task brushTeethTask = Task.Factory.StartNew(action: BrushTeeth);
            Task washFaceTask = Task.Factory.StartNew(action: WashFace);
            Task.WaitAll(dressTask, brushTeethTask, washFaceTask);
            sw.Stop();
            Console.WriteLine($"...早起三件事完成, 总耗时 {sw.Elapsed.Seconds} 秒");
            Console.ReadKey();
        }

        /// <summary>
        /// 穿衣
        /// </summary>
        static void Dress()
        {
            Console.WriteLine($"穿衣开始...");
            Stopwatch sw = new Stopwatch();
            sw.Start();
            Thread.Sleep(timeout: TimeSpan.FromSeconds(value: 1));
            sw.Stop();
            Console.WriteLine($"...穿衣完成, 耗时 {sw.Elapsed.Seconds} 秒");
        }

        /// <summary>
        /// 刷牙
        /// </summary>
        static void BrushTeeth()
        {
            Console.WriteLine($"刷牙开始...");
            Stopwatch sw = new Stopwatch();
            sw.Start();
            Thread.Sleep(timeout: TimeSpan.FromSeconds(value: 3));
            sw.Stop();
            Console.WriteLine($"...刷牙完成, 耗时 {sw.Elapsed.Seconds} 秒");
        }

        /// <summary>
        /// 洗脸
        /// </summary>
        static void WashFace()
        {
            Console.WriteLine($"洗脸开始...");
            Stopwatch sw = new Stopwatch();
            sw.Start();
            Thread.Sleep(timeout: TimeSpan.FromSeconds(value: 5));
            sw.Stop();
            Console.WriteLine($"...系列完成, 耗时 {sw.Elapsed.Seconds} 秒");
        }
    }
}

启动运行之后, 等待一会, 你应该会看到如下输出:

早起三件事开始...
刷牙开始...
洗脸开始...
穿衣开始...
...穿衣完成, 耗时 1 秒
...刷牙完成, 耗时 3 秒
...系列完成, 耗时 5 秒
...早起三件事完成, 总耗时 5 秒

可以看到, 几件事一起干了, 总耗时只用了 5 秒.

总结一下

几件事一起干(并行), 比一件一件事慢慢来

  • 要省时间, 但是要多写点代码, 更耗体力.
  • 可以使用 Task 来轻松实现并行操作.
  • ...

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对脚本之家的支持。如果你想了解更多相关内容请查看下面相关链接

相关文章

  • C#/.Net 中快速批量给SQLite数据库插入测试数据

    C#/.Net 中快速批量给SQLite数据库插入测试数据

    这篇文章主要介绍了C#/.Net 中快速批量给SQLite数据库插入测试数据,本文直接给出实例代码,需要的朋友可以参考下
    2015-06-06
  • c# 反射用法及效率对比

    c# 反射用法及效率对比

    这篇文章主要介绍了c# 反射用法及效率对比,帮助大家更好的理解和学习使用c#,感兴趣的朋友可以了解下
    2021-02-02
  • C#开发WinForm根据条件改变DataGridView行颜色

    C#开发WinForm根据条件改变DataGridView行颜色

    这篇文章介绍了C#开发WinForm根据条件改变DataGridView行颜色的方法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-03-03
  • C# XML文件操作之相机参数保存和读取

    C# XML文件操作之相机参数保存和读取

    XML是可扩展标记语言是一种数据语言,它将数据以一种简单的文本格式存储,可以被人类和几乎任何计算机理解。本文将利用C#实现相机参数读取并保存至XML文件,感兴趣的可以学习一下
    2022-11-11
  • C#中枚举的特性 FlagAttribute详解

    C#中枚举的特性 FlagAttribute详解

    说到FlagsAttribute,源自前几天看到了一小段代码,大概意思就是根据航班政策来返回哪些配送方式是否可用,根据这些是否可用来隐藏或者开启界面的相关配送方式,不是非常明白,于是今天我们就来详细探讨下这个问题
    2018-03-03
  • unity实现车方向盘转动效果

    unity实现车方向盘转动效果

    这篇文章主要为大家详细介绍了unity实现车方向盘转动效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-04-04
  • C#查询SqlServer数据库并返回单个值的方法

    C#查询SqlServer数据库并返回单个值的方法

    这篇文章主要介绍了C#查询SqlServer数据库并返回单个值的方法,涉及C#操作SQLServer数据库查询的相关技巧,需要的朋友可以参考下
    2015-06-06
  • unity实现物体延时出现

    unity实现物体延时出现

    这篇文章主要为大家详细介绍了unity实现物体延时出现,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-04-04
  • c#调用vc写的ocx控件示例

    c#调用vc写的ocx控件示例

    这篇文章主要介绍了c#调用vc写的ocx控件示例,需要的朋友可以参考下
    2014-04-04
  • unity 如何修改材质属性和更换shader

    unity 如何修改材质属性和更换shader

    这篇文章主要介绍了unity 修改材质属性和更换shader的操作方式,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-04-04

最新评论