- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
<ucontext.h>
中的用户线程函数已弃用,因为它们使用了已弃用的 C 功能(它们 use a function declaration with empty parentheses for an argument )。
是否有标准的替代品?我觉得成熟的线程不擅长实现协作线程。
最佳答案
如果您真的想做 ucontext.h
函数允许的事情,我会继续使用它们。其他任何东西都不那么便携。在 POSIX 中将它们标记为过时似乎是委员会中某人犯下的一个可怕的迂腐错误。 POSIX 本身要求函数指针和数据指针的大小相同,并且函数指针可表示为 void *
,而 C 本身要求在函数指针类型之间进行转换并返回是往返安全的, 所以有很多方法可以解决这个问题。
有一个真正的问题,将传递给 makecontext
的 int argc, ...
转换成一种形式传递给函数,如果没有来自编译器,除非可变函数和非可变函数的调用约定恰好相同(即便如此,它是否可以稳健地完成也是相当值得怀疑的)。然而,这个问题本来可以简单地通过以 makecontext(ucp, func, 1, (void *)arg);
以外的任何形式弃用 makecontext
来解决。
也许更好的问题是为什么您认为 ucontext.h
函数是处理线程的最佳方式。如果您确实想使用它们,我可能建议编写一个包装器接口(interface),您可以使用 ucontext.h
或 使用 pthreads 实现或者,然后比较性能和膨胀。这还有一个好处,如果 future 的系统不再支持 ucontext.h
,您可以简单地切换到使用基于 pthread 的实现进行编译,一切都会简单地工作。 (到那时,膨胀可能不那么重要,多核/SMP 的好处可能会很大,希望 pthread 实现不会那么膨胀。)
编辑(根据 OP 的要求):要使用 pthreads 实现“协作线程”,您需要条件变量。这是一个不错的 pthreads 教程,其中包含有关使用它们的信息:
https://computing.llnl.gov/tutorials/pthreads/#ConditionVariables
“将执行移交给线程 X”的协作式多任务原语将如下所示:
self->flag = 0;
other_thread->flag = 1;
pthread_mutex_lock(other_thread->mutex);
pthread_cond_signal(other_thread->cond);
pthread_mutex_unlock(other_thread->mutex);
pthread_mutex_lock(self->mutex);
while (!self->flag)
pthread_cond_wait(self->cond, self->mutex);
pthread_mutex_unlock(self->mutex);
希望我没搞错;至少总体思路是正确的。如果有人看到错误,请发表评论,以便我进行修复。一半的锁定(other_thread
的互斥锁)对于这种用法可能是完全不必要的,因此您可以将互斥锁设为 task_switch
函数中的局部变量。您真正要做的就是使用 pthread_cond_wait
和 pthread_cond_signal
作为“进入休眠”和“唤醒其他线程”原语。
关于c - 有什么东西可以代替 <ucontext.h> 函数吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4298986/
我问的平台是linux。我说的线程本地存储是gcc中的pthread_xxx或__thread。 我想在我的程序中使用 ucontext 东西,即 makecontext、swapcontext 等。
我读到 ucontext 用于在 linux 中保存多个线程之间的上下文。既然OS做的是不同线程之间的上下文切换,为什么linux要提供这个头文件(ucontext.h)来进行上下文切换呢? 最佳答案
Boost v1.59 中的 Boost.Context 文档报告了以下性能比较结果: +----------+----------------------+-------------------+-
使用 gcc,我在编译使用 ucontext.h 的东西时遇到这些错误 /usr/include/sys/ucontext.h: At top level: /usr/include/
cygwin 似乎不支持用户上下文切换(由 ucontext.h 支持)。 鉴于我需要在 cygwin 下开发一个用户上下文切换应用程序,有什么解决方案吗? 最佳答案 您可能可以编写自己的实现,环绕
我正在尝试将使用 ucontext 的库移植到支持 pthread 但不支持 ucontext 的平台。代码写得很好,因此用对 pthread 例程的调用替换对 ucontext API 的所有调用应
中的用户线程函数已弃用,因为它们使用了已弃用的 C 功能(它们 use a function declaration with empty parentheses for an argument )
所以我正在尝试解除分配上下文。 这是我创建上下文的方式 ucontext* uPtr = new ucontext; getcontext(uPtr); char* stack = new char[
当我在下面编译我的代码时,它会打印 I am running :) 永远(直到我向程序发送 KeyboardInterrupt 信号), 但是当我取消注释 //printf("done:%d\n",
这里是代码,不知道每个detain是什么意思,比如REG_RIP,什么是“RIP” //ucontext.h enum { //... REG_RIP, //... } here是完整代码 最佳答
我正在为操作系统类(class)做一个项目。任务是实现一个处理线程的库,类似于 pthreads,但要简单得多。它的目的是练习调度算法。最终产品是一个 .a 文件。类(class)结束,一切正常(在功
作为更大的线程调度 api 的一部分,这是我想做的事情。 我想创建一个线程,当主线程(创建线程的线程)退出时,我刚创建的线程应该执行。我正在尝试使用 ucontext 和 uc_link 执行此操作,
我去年学习了操作系统,期间我使用用户上下文(在头文件 ucontext.h 中定义)为一个项目实现线程调度程序(其中每个线程模拟一个进程)。我正在参加一个讲座,将讨论用户上下文,我突然想到,尽管去年完
嗨,我需要从一个地方跳到另一个地方... 但我想知道哪个更好用,setjmp 或 ucontext,例如: setjmp 和 ucontext 是否可移植? 我的代码使用这些库是线程安全的吗? 为什么
据我所知,ucontext 提供了比 setjmp 更好的东西。但它已被弃用,现在已从 POSIX 规范中删除。那么它为什么会出现,又为什么会被移除? 最佳答案 makecontext的签名来自 uc
我正在设计一个具有以下功能的调度算法: 在一个进程中有 2 个用户线程(上下文)(我应该做 3 个线程,但在 osx 上还不起作用,所以我决定现在让 2 个工作) 使用每 1 秒关闭一次的 SIGAL
我正在使用 ucontext 开发一个简单的、具有教育意义的绿色(合作)基于量子的线程示例。但我面临着问题。下面提供的示例非常容易理解,我将感谢您为我提供的任何帮助: TestApp.java: pu
我的代码在这里: #define _GNU_SOURCE #include "lib-ult.h" #include #include #include #include #define TR
我有这个最小的 helloworld,扩展了 ucontext.h: #include #include int main(int argc, char** argv) { printf ("
我正在尝试使用 ucontext 例程来实现多线程库。运行此代码时出现“浮点异常(核心已转储)”。 #include #include #include typedef struct {
我是一名优秀的程序员,十分优秀!