首頁 > 後端開發 > C++ > 如何使用「ThreadPool.QueueUserWorkItem」和「Task.Run」在 C# 中進行非阻塞方法呼叫?

如何使用「ThreadPool.QueueUserWorkItem」和「Task.Run」在 C# 中進行非阻塞方法呼叫?

Patricia Arquette
發布: 2025-01-18 16:02:09
原創
973 人瀏覽過

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

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

在C#中,可以非阻塞地執行方法,允許執行緒在無需等待方法完成的情況下繼續執行。

最直接的方法是使用ThreadPool.QueueUserWorkItem方法。它接受一個WaitCallback委託作為參數,該委託指定要非同步執行的方法。

範例:

<code class="language-csharp">using System.Threading;

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

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

    static void FireAway()
    {
        Thread.Sleep(5000);
        Console.WriteLine("5秒后执行");
    }
}</code>
登入後複製

在這個範例中,FireAway方法被排入執行緒池,主執行緒在啟動非同步呼叫後立即繼續執行。

另一個方法:Task.Run

一種更現代、更簡潔的非同步運行任務的方法是使用Task.Run方法,它會傳回一個表示非同步操作的Task物件。

範例:

<code class="language-csharp">using System.Threading.Tasks;

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

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

    static void FireAway()
    {
        Thread.Sleep(5000);
        Console.WriteLine("5秒后执行");
    }
}</code>
登入後複製

ThreadPool.QueueUserWorkItemTask.Run都提供了在C#中非阻塞執行方法的有效方法。但是,在不同的場景中使用這些技術時,請務必考慮其潛在的影響和限制。

以上是如何使用「ThreadPool.QueueUserWorkItem」和「Task.Run」在 C# 中進行非阻塞方法呼叫?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板