首页 > 后端开发 > C++ > 如何使用'ThreadPool.QueueUserWorkItem”和'Task.Run”在 C# 中进行非阻塞方法调用?

如何使用'ThreadPool.QueueUserWorkItem”和'Task.Run”在 C# 中进行非阻塞方法调用?

Patricia Arquette
发布: 2025-01-18 16:02:09
原创
1021 人浏览过

How to Make Non-Blocking Method Calls in C# Using `ThreadPool.QueueUserWorkItem` and `Task.Run`?

C#中的非阻塞方法调用:ThreadPool.QueueUserWorkItemTask.Run 的使用

在C#中,可以非阻塞地执行方法,允许线程在无需等待方法完成的情况下继续执行。

最直接的方法是使用ThreadPool.QueueUserWorkItem方法。它接受一个WaitCallback委托作为参数,该委托指定要异步执行的方法。

示例:

using System.Threading;

class Foo
{
    static void Main()
    {
        // FireAway将在后台执行
        ThreadPool.QueueUserWorkItem(o => FireAway());

        Console.WriteLine("立即执行");
    }

    static void FireAway()
    {
        Thread.Sleep(5000);
        Console.WriteLine("5秒后执行");
    }
}
登录后复制

在这个例子中,FireAway方法被排入线程池,主线程在启动异步调用后立即继续执行。

另一种方法:Task.Run

一种更现代、更简洁的异步运行任务的方法是使用Task.Run方法,它返回一个表示异步操作的Task对象。

示例:

using System.Threading.Tasks;

class Foo
{
    static void Main()
    {
        // FireAway将在后台执行
        Task.Run(() => FireAway());

        Console.WriteLine("立即执行");
    }

    static void FireAway()
    {
        Thread.Sleep(5000);
        Console.WriteLine("5秒后执行");
    }
}
登录后复制

ThreadPool.QueueUserWorkItemTask.Run都提供了在C#中非阻塞执行方法的有效方法。但是,在不同的场景中使用这些技术时,务必考虑其潜在的影响和局限性。

以上是如何使用'ThreadPool.QueueUserWorkItem”和'Task.Run”在 C# 中进行非阻塞方法调用?的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板