Multithreading 是否可以将任务固定到特定线程?
Julia的多线程系统构建在任务之上。我可以创建一个异步任务,该任务将始终在生成它的线程上运行,该线程使用Multithreading 是否可以将任务固定到特定线程?,multithreading,julia,Multithreading,Julia,Julia的多线程系统构建在任务之上。我可以创建一个异步任务,该任务将始终在生成它的线程上运行,该线程使用@async。我可以创建一个任务,该任务可以在具有线程的任何线程上运行。@spawn。或者,我可以使用线程将整个for循环拆分为所有可用线程。@threads for… 如何将任务放到我所选择的特定线程上?这不是创建它的线程?一种方法是使用。它提供了一个@tspawnat宏,允许在特定线程上生成任务 示例:(取自程序包的README.md) 可以找到宏的实现。谢谢!这个软件包的诞生是因为Ba
@async
。我可以创建一个任务,该任务可以在具有线程的任何线程上运行。@spawn
。或者,我可以使用线程将整个for
循环拆分为所有可用线程。@threads for…
如何将任务放到我所选择的特定线程上?这不是创建它的线程?一种方法是使用。它提供了一个@tspawnat
宏,允许在特定线程上生成任务
示例:(取自程序包的README.md)
可以找到宏的实现。谢谢!这个软件包的诞生是因为BaseJulia本身缺少这个API;有关更多详细信息,请参阅问题。请注意,宏的实现也可以以特别的方式使用——它实际上只需要几行代码。(您可以忽略整个
if$(Expr(:islocal,var))
块,因为只有当您希望封闭@sync
宏以等待任务时才需要它;这只是粘性
更改和调用)
julia> t = @tspawnat 4 Threads.threadid()
Task (runnable) @0x0000000010743c70
julia> fetch(t)
4