我使用Julia (1.2.0)中的ccall来调用我在多个内核中运行的循环中创建的c函数:
Threads.@threads for i in 1:10
ccall((:myfunction, "myclib", (...), input[i])
end这个实现在没有Threads.@Threads.的情况下运行良好,但当我使用Threads.@Threads.时,由于分段错误而崩溃,我不知道原因。我检查了我在myclib中使用的所有c函数,它们都是线程安全的。
我的问题是:在这种实现中,运行在c上的函数是线程独立的还是以某种方式联系在一起的?例如,它们是否共享全局变量?或者堆栈内存限制是单独应用于每个线程,还是应用于所有线程使用的内存?
谢谢你的帮忙,
迪伦
发布于 2019-11-11 18:11:58
我通过在c中删除myfunction的所有全局变量解决了这个问题。然而,我并不真正理解在使用ccall和多线程调用c函数时,全局变量是如何工作的。
https://stackoverflow.com/questions/58780533
复制相似问题