将 int 函数转换为 void*

标签 c linux void-pointers

我在将返回的整数值转换为 void 指针时遇到问题。已从该站点尝试了一些选项,但我的问题似乎仍未解决。尽管程序编译时没有代码错误,但我遇到了段错误。我是不是瞎了,我的代码中有没有错误?

#include<pthread.h>
#include<stdio.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)));
    }
}

int main(int argc, char* argv[])
{
    int a = atoi(argv[1]);
    int b = atoi(argv[2]);
    int c = ackermann(a,b);
    void *ptr = &c;
    pthread_t mythread;
    if(pthread_create(&mythread, NULL, ptr, NULL))
    {
        printf("Could not create a thread\n");
    }

    pthread_exit(NULL);
    return 0;
}

最佳答案

如评论中所述,您实际上并未在单独的线程中调用函数 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;
}

关于将 int 函数转换为 void*,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36793252/

相关文章:

c - 如何只读取 typedef 结构中的第一个参数?

c - 在头文件中声明结构

c - DHCP服务器发送的DHCP选项信息将存储在Linux机器的哪里?

C++ 如何在两个不同项目中的静态变量之间发生链接

c++ - 将指向 T 的指针存储在 void* 中,但 T 可以是常量或非常量 - 使用 void const* 还是仅使用 void*?

c - 从 void ** 转换为 char ** 有多危险

c - C语言中声明void**是什么意思?

c - 未分配被释放的指针(仅限 osx)

c-select() 识别第一个 fd 未阻塞的 select for read/recv operation

python - 处理来自 gunicorn 的请求