0

晚上的最后一个问题。我有一个我似乎无法解决的家庭作业问题,在花了大半夜的时间解决它之后,我会在这里问它。

问题是一个程序,该程序要在命令行输入一个整数来计算斐波那契数列(例如,./foo.out 15,它将计算前 15 个斐波那契数)。附加参数如下:

1.) 它必须使用两个 POSIX 线程,一个父线程和一个子线程。2.) 它必须在它们之间共享数据(一个数组)。

目前,当程序控制权传递回父线程时,该函数正在中断。我得到的只是一个完全非描述性的段错误。如下所示,我让它在每次可能的控制变化时输出。

代码:

#include <stdio.h>
#include <pthread.h>
#include <unistd.h>
#include <stdlib.h>

void *fibonacci(void *param, int numbers[]);
void *runner(void *param);

int main(int argc, char *argv[])
{
  pthread_t tid;
  pthread_attr_t attr;


  if ( argc != 2)
    {
      fprintf(stderr, "Usage: 426.out <integer value> \n");
      return -1;
    }

  if (atoi(argv[1]) < 0)
    {
      fprintf(stderr, "Argument must be non-negative\n");
      return -2;
    }

      pthread_attr_init(&attr);
      pthread_create(&tid, &attr, runner, argv[1]);
      pthread_join(tid,NULL);

  return 0;
}

void *fibonacci(void *param, int numbers[])
    {
      int it, IT_MAX;

      printf("Entering Child Thread:\n");

      IT_MAX = atoi(param);
      numbers[0] = 0;
      numbers[1] = 1;

      for (it = 2; it < IT_MAX; ++it)
    {
      numbers[it] = (numbers[it - 1] + numbers[it - 2]);
    }
      for (it = 0; it < IT_MAX; ++it)
    {
      printf("%d\n", numbers[it]);
    }

      printf("Exiting Child Function.\n");
    }

  void *runner(void *param)
  {
    int it, IT_MAX;
    int numbers[IT_MAX];

    pthread_t tid;
    pthread_attr_t attr;

    printf("Entering Parent Thread:\n");


    pthread_attr_init(&attr);
    pthread_create(&tid, &attr, fibonacci(param, numbers), NULL);
    pthread_join(tid, NULL);

    IT_MAX = atoi(param);    

    for (it = 0; it < IT_MAX; it++)
      {
    printf("%d\n", numbers[it]); // I suspect the program breaks here
                                   // It produces a segfault rather than this
      }

    printf("Leaving Parent Thread\n");
  }

如果从上面不清楚,我的问题是我做错了什么。我正在使用 gcc,并且一直在使用-Wall -Werrorand -lpthread-Werror不断抛出“控制结构将结束非空函数”,但对于导致段错误的原因没有什么可说的。和以前一样,我在最后一小时寻找解决这个问题的问题或文章,所以如果这是一个骗局,请指出我解决它的问题或文章。提前感谢任何人的帮助。

4

2 回答 2

3

您的问题之一是在这一行:

pthread_create(&tid, &attr, fibonacci(param, numbers), NULL);

fibonacci()这不是使用该函数启动线程,而是调用当前线程中的fibbonacci()函数并将结果pthread_create()作为线程启动函数传递给。 fibonacci()不返回函数指针,所以这个新线程会使程序崩溃。

您只需要fibonacci作为第三个参数传递。

此外,fibonacci()必须声明为void *fibonacci(void *)才能用作线程启动函数。如果要传递两个参数,则需要将它们放入 astruct并传递一个指向它的指针。

这对线也有问题:

int it, IT_MAX;
int numbers[IT_MAX];

IT_MAX是一个未初始化的变量,你在这里使用它来定义numbers[]数组的大小。这也可能导致您的崩溃。

于 2013-10-19T08:54:57.820 回答
1

这条线

pthread_create(&tid, &attr, fibonacci(param, numbers), NULL);

不传递 to 的地址,fibonacci()而是pthread_create()调用fibonacci(param, numbers)并将返回的结果pthread_create()作为第三个参数传递给。

于 2013-10-19T08:51:46.337 回答