如何在简单的Pthread编程中分配数组变量?

时间:2013-03-02 16:16:27

标签: c arrays pthreads variable-assignment

我是Pthread编程的新手。

我一直在尝试以一种非常简单的方式使用Pthread,如下面的代码,并且它在我的CodeBlock中运行良好,因为我已经包含了dll和bin文件。

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

void *printNumber(void *x);

int main(){
    pthread_t threadA, threadB, threadC, threadD;
    pthread_create(&threadA, NULL, printNumber, (void *)"Sponge");
    pthread_create(&threadB, NULL, printNumber, (void *)"Star");
    pthread_create(&threadC, NULL, printNumber, (void *)"Squid");
    pthread_create(&threadD, NULL, printNumber, (void *)"Crab");
    pthread_exit(NULL); 
    return 0;
}

void *printNumber(void *x){
    char* id = (char*)x;
    int i;
    for(i=0;i<100;i++){
        printf("Thread %s: printing integer value %i\n", id, i);
    }
    pthread_exit(NULL);
}

然后我编写另一个简单的程序,使用Pthread将2个数组(arrayA + arrayB)添加到arrayC中。 这是我的简单代码。 在main()中,所有内容都是硬编码,没有循环等,因为我想尽可能简单地让我理解如何创建单个Pthread。

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

#define SIZE 16
#define UPPER_RAND 100
#define NUM_THREADS 4

// HEADER PROCEDURES    
void randomGenerator(int arr[]);
void printArray(int arr[]);
void *addArrayPthread(void *x);

typedef struct {
    int startIdx;
    int arrC[SIZE], arrA[SIZE], arrB[SIZE];
} someType;

int main(){
    printf("A Simple Program To Add Arrays Using PThread\n");
    int arrayA[SIZE];
    int arrayB[SIZE];
    int arrayC[SIZE];

    randomGenerator(arrayA);
    printArray(arrayA);

    randomGenerator(arrayB);
    printArray(arrayB);

    someType *w,*x,*y,*z;
    w = (someType*) malloc(sizeof(someType));
    x = (someType*) malloc(sizeof(someType));
    y = (someType*) malloc(sizeof(someType));
    z = (someType*) malloc(sizeof(someType));

    (*w).startIdx = 0;
    (*w).arrA = arrayA;
    (*w).arrB = arrayB;
    (*w).arrC = arrayC;

    (*x).startIdx = 4;
    (*x).arrA = arrayA;
    (*x).arrB = arrayB;
    (*x).arrC = arrayC;

    (*y).startIdx = 8;
    (*y).arrA = arrayA;
    (*y).arrB = arrayB;
    (*y).arrC = arrayC;

    (*z).startIdx = 12;
    (*z).arrA = arrayA;
    (*z).arrB = arrayB;
    (*z).arrC = arrayC;


    pthread_t threadA, threadB, threadC, threadD;
    pthread_create(&threadA, NULL, addArrayPthread, (void *)w);
    pthread_create(&threadB, NULL, addArrayPthread, (void *)x);
    pthread_create(&threadC, NULL, addArrayPthread, (void *)y);
    pthread_create(&threadD, NULL, addArrayPthread, (void *)z);

    pthread_join(threadA, NULL);
    pthread_join(threadB, NULL);
    pthread_join(threadC, NULL);
    pthread_join(threadD, NULL);

    return 0;
}


//=====================================================================================//

void randomGenerator(int arr[]){
    printf("Generating random value for the array...\n");
    int i;
    for (i=0;i<SIZE;i++){
        arr[i] = (rand() % UPPER_RAND);
    }
}

void printArray(int arr[]){
    printf("Display the array value...\n");
    int i;
    printf("[");
    for (i=0;i<SIZE;i++){
        printf("%i, ",arr[i]);
    }
    printf("]\n");
}

void *addArrayPthread(void *x){
    someType *p = (someType *) x;
    printf("Adding to arrays, starting from index #%i\n",(*p).startIdx);
    int blockSize = SIZE/NUM_THREAD;
    int end = (*p).startIdx + blockSize;
    int i;
    for (i=(*p).startIdx;i<end;i++){
        (*p).arrC[i] = (*p).arrA[i] + (*p).arrB[i];
    }
}

我在这些行周围收到12条错误消息: (* x).arrA = arrayA;等等

||In function `int main()':|
\pth_array.c|58|error: ISO C++ forbids assignment of arrays|

这是我的问题:

  1. 为什么禁止数组的分配?以及如何解决?
  2. 在上面的第一个程序中,我将 pthread_exit(NULL)两次放入: main()和void *函数。我想我只需要把它放一次。那我到底要把它放在哪里呢?在main()或void *函数中?
  3. 是否必须在返回0之前将 pthread_join 放在main()中?
  4. 提前谢谢你。 你的解释对我很有帮助。

    由于

    P.S。:我在下面的部分中发布了另一个类似的问题(关于矩阵)。

2 个答案:

答案 0 :(得分:3)

如下:

typedef struct {
    int startIdx;
    int *arrC, *arrA, *arrB;
} someType;

[...]

x->arrA = arrayA
[...]

需要pthread_join,因为您希望在退出应用程序之前等待每个线程完成。

答案 1 :(得分:0)

那么,

  1. 您不能直接在C中复制数组。已经很好地解释了here
  2. 明确说明了pthread_exit的确切功能here;示例也可用here。也就是说,调用应该放在printNumber(void * x)而不是main()中。
  3. 明确指出了pthread_join的确切功能here。因此,要将控制传递给线程,需要pthread_join调用。