- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
#include <stdio.h>
#include <stdlib.h>
#define _XOPEN_SOURCE 600
#include <ucontext.h>
/* Tests creation.
Should print "Hello World!" */
typedef struct thread_t{
ucontext_t thread_context;
}thread_t;
void *thr1(void *in) {
printf("Hello World!\n");
fflush(stdout);
return NULL;
}
void *thr2(void *in) {
printf("goodbye World!\n");
fflush(stdout);
return NULL;
}
int main() {
thread_t t1;
thread_t t2;
thread_create( &t1, thr1, NULL);
// if you comment out the following line, the program will run like a charm.
thread_create( &t2, thr2, NULL);
setcontext(&t1.thread_context);
return EXIT_SUCCESS;
}
void thread_routine(void *(*start_routine)(void *), void *arg)
{
start_routine(arg);
printf("gtthread routine finished\n");
}
int thread_create(thread_t *thread,
void *(*start_routine)(void *),
void *arg){
if (getcontext(&(thread->thread_context)) == -1)
{
perror("getcontext");
}
thread->thread_context.uc_stack.ss_sp = (char*) malloc(SIGSTKSZ);
thread->thread_context.uc_stack.ss_size = SIGSTKSZ;
thread->thread_context.uc_link = NULL;
makecontext(&(thread->thread_context), thread_routine, 2, (void *)start_routine, arg);
}
我在 OS X 10.10 中使用 gcc 运行我的代码。我正在尝试实现用户上下文库。
如果我注释掉 thread_create( &t2, thr2, NULL);
,代码将产生预期的效果。我不知道为什么与 t2
相关的行会导致 t1
的段错误。
切换到 Ubuntu 后,我很高兴地致力于实现用户上下文库。一切正常。不再有段错误。正如预期的那样,它在 OS X 10.10 上崩溃了。
我的猜测是,由于 makecontext()、swapcontext() 等在 OS X 上自 10.6 以来已被弃用,正如编译器所警告的那样,我不应该期望它会起作用。
最佳答案
你的程序有一些缺陷,其中一些导致它产生未定义的行为。未定义的行为可能会完全按照您的预期表现出来,但如果它碰巧在某些特定环境中出现过一次,则没有任何理由期望它会再次出现——不是在那个环境中,并且当然不是在不同的环境中。
以下是我注意到的更严重的问题:
thread_routine()
没有上下文启动函数的正确返回类型或参数类型。上下文启动函数应返回 void
(即什么都没有)而不是 void *
,这是完全不同的。此外,传递给它的实际参数(如果有的话)都将是 int
类型。因此,当您的程序因 setcontext()
而调用此函数时,会产生未定义的行为。在函数指针和对象指针都与 int
大小相同的机器上,您可能会侥幸逃脱,但在其他机器上,程序可能会严重崩溃。这可能是您观察到的段错误的原因。
在 thread_create()
中,您将 thread->thread_context.uc_link
初始化为 NULL
。这本身并不是一个错误,但从更大的角度来看,它会产生这样的效果:当上下文的启动函数返回时,运行它的(操作系统)线程将退出。据推测,您更愿意有机会在不同的环境中交换。
您使用 setcontext()
切换到 t1
上下文。如果成功,此调用既不会返回,也不会返回,使您无法稍后切换到 t2
上下文。但实际上,当 t1 的 start 函数返回时(见上文),线程和整个程序无论如何都会退出,所以这对你来说没有实际意义。不过,就其值(value)而言,您可能应该改用 swapcontext()
。
thread_create()
被声明为返回一个int
,但它没有return
语句。
gcc
应该发出关于其中一些问题的警告。如果不是,则调高警告级别。 -Wall
级别应该足够了,但我也经常打开 -Wextra
来查找问题。有时您可以安全地忽略一些警告(尤其是使用 -Wextra
),但您应该对每一个警告单独进行评估。
关于c - OS X 10.10 上 ucontext makecontext 的段错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32703891/
我问的平台是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 {
我是一名优秀的程序员,十分优秀!