将int函数转换为void *

时间:2016-04-22 11:58:09

标签: c linux void-pointers

我将返回的整数值转换为void指针时遇到问题。尝试过这个网站的一些选项,但我的问题似乎仍未解决。虽然程序编译没有代码错误,但我遇到了分段错误。我是盲人,我的代码中是否有错误?

{{1}}

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, &params))
    {
        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;
}