當前位置: 首頁>>代碼示例 >>用法及示例精選 >>正文


Elixir Task.completed用法及代碼示例


Elixir語言中 Task.completed 相關用法介紹如下。

用法:

completed(result)
(從 1.13.0 開始)
@spec completed(any()) :: t()

啟動一個使用給定 result 立即完成的任務。

async/1 不同,此任務不會產生鏈接進程。它可以像任何其他任務一樣被等待或屈服。

用法

在某些情況下,創建一個"completed" 任務來表示已經運行並生成結果的任務很有用。例如,在處理數據時,您可能能夠在分派某些輸入進行進一步處理之前確定某些輸入是無效的:

def process(data) do
  tasks =
    for entry <- data do
      if invalid_input?(entry) do
        Task.completed({:error, :invalid_input})
      else
        Task.async(fn -> further_process(entry) end)
      end
    end

  Task.await_many(tasks)
end

在許多情況下,可以避免使用 Task.completed/1 ,而是直接返回結果。當一組輸入將部分同步和部分異步處理時,您通常應該隻在使用混合異步時才需要此變體。

相關用法


注:本文由純淨天空篩選整理自elixir-lang.org大神的英文原創作品 Task.completed(result)。非經特殊聲明,原始代碼版權歸原作者所有,本譯文未經允許或授權,請勿轉載或複製。