我将返回的整数值转换为void指针时遇到问题。尝试过这个网站的一些选项,但我的问题似乎仍未解决。虽然程序编译没有代码错误,但我遇到了分段错误。我是盲人,我的代码中是否有错误?
{{1}}
答案 0 :(得分:2)
正如评论中提到的,您实际上并没有在单独的线程中调用函数ackermann
。你正在做的是直接从main
调用函数,将结果存储在int
中,并将指向int
的指针作为第三个参数传递给pthread_create
,应该是指向要运行的函数的指针。
目前,ackermann
没有相应的签名传递给pthread_create
。启动新线程的函数应该声明如下:
void *my_thread_function(void *parameter);
鉴于递归调用ackermann
,将包装器函数传递给pthread_create
并让包装器调用ackermann
而不是修改ackermann
以匹配以上签名。
因为您需要将多个参数传递给线程函数,所以您需要创建一个包含所有参数的struct
并将指向该struct
的指针传递给线程函数。
您还可以将返回值存储在此结构中,以便启动该线程的函数可以访问它。
#include<pthread.h>
#include<stdio.h>
#include<stdlib.h>
#include<stdint.h>
int ackermann(int a, int b)
{
if(a==0) {
return a+1;
} else if(a>0 && b==0) {
return ackermann(a-1, 1);
} else if(a>0 && b>0) {
return ackermann(a-1,ackermann(a,(b-1)));
}
// if none of the above conditions are true, no value is returned
// better check for this
}
struct ackermann_params {
int a;
int b;
int result;
};
void *ackermann_thr(void *arg)
{
struct ackermann_params *params = arg;
params->result = ackermann(params->a, params->b);
return NULL;
}
int main(int argc, char* argv[])
{
struct ackermann_params params;
if (argc < 3) {
printf("invalid number of arguments\n");
exit(1);
}
params.a = atoi(argv[1]);
params.b = atoi(argv[2]);
pthread_t mythread;
if(pthread_create(&mythread, NULL, ackermann_thr, ¶ms))
{
perror("Could not create a thread\n");
exit(1);
}
if (pthread_join(mythread, NULL)) {
perror("join failed\n");
exit(1);
}
printf("result=%d\n", params.result);
return 0;
}