0

我有一个家庭作业问题,我目前被困在上面。问题的参数如下。1.) 它必须接受来自用户的总共 5 个整数。

2.) 它必须有三个线程,每个线程执行不同的功能(平均、最小值和最大值)。

我遇到的问题是声明一个包含 5 个元素的全局数组空数组,然后修改这些元素。每次我以一个段错误结束时,告诉我我做错了。顺便说一句,该语言是 C,强调不是 C++(我不允许使用它)。如果有人可以帮助我了解问题所在,我将不胜感激。另外,如果它是重复的(我看了,我没有看到任何解决这些问题的方法),请指出我解决它的问题或文章谢谢。

代码:

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

void *avgWorker(int in[]);
void *minWorker(int in[]);
void *maxWorker(int in[]);

int main(void)
{
  int it, *input;

  int in[5];

  pthread_t tid1,tid2,tid3;
  pthread_attr_t attr1, attr2,attr3;

  for (it = 0; it < 5; ++it)
    {
      printf("Please enter number %d of 5\n", (it + 1));

      input[it] = scanf("%d");
    }

  pthread_attr_init(&attr1);
  pthread_attr_init(&attr2);
  pthread_attr_init(&attr3);

  pthread_create(&tid1, &attr1, avgWorker(in), NULL);
  pthread_create(&tid2, &attr2, minWorker(in), NULL);
  pthread_create(&tid3, &attr3, maxWorker(in), NULL);

  pthread_join(tid1,NULL);
  pthread_join(tid2,NULL);
  pthread_join(tid3,NULL);

  return 0;
}

void *avgWorker(int in[])
{
  int total, avg, it;

  total = 0;

  for (it = 0; it < 5; ++it)
    {
      total += in[it];
    }

  avg = 0;

  avg = total / 5;

  printf("\n The average value is: %d. \n", avg);
}

void *minWorker(int in[])
{
  int min, it;
  min = 99999;

  for (it = 0; it < 5; ++it)
    {
      if (in[it] < min)
    min = in[it];
    }

  printf("The minimum value is: %d\n", min);
}

void *maxWorker(int in[])
{
  int max, it;

  max = -99999;

  for (it = 0; it < 5; ++it)
    {
      if (in[it] > max)
    max = in[it];
    }

   printf("The maximum value is: %d \n", max);
}

最后,我正在使用 gcc 编译这段代码,并使用 -lpthread 标志。再次感谢您提供的任何帮助。

4

2 回答 2

5

这是它应该崩溃的地方:

input[it] = scanf("%d");

scanf返回读取的字段数,而不是读取的数据。存储数据的变量地址应作为参数传递。像这样:

scanf("%d", &input[it]);

input只是一个未初始化的指针。它没有指向任何地方(有意义)。我猜你想要in,不是input。你根本不需要input变量。

于 2013-10-18T22:13:30.210 回答
3

你的问题是在线

input[it] = scanf("%d");

查找scanf...的语法,您需要提供存储数据的地址,因此

scanf("%d", input+it);

应该是一个改进。或者 - 正如@dreamlax 所指出的,为了更易读的代码

scanf("%d", &input[it]);
于 2013-10-18T22:14:13.137 回答