尝试使用pthreads访问共享数据阵列时,无法访问内存地址

时间:2013-08-20 07:55:58

标签: c++ debugging parallel-processing segmentation-fault pthreads

我有一个带有两个线程的pthread程序。第一个线程写入数组[0 - 196607],第二个线程写入数组[196608 - 393215]。

访问数组元素[33779到393215]时,我收到“无法访问内存地址...”错误。因为这个我得到了一个段错误。有人可以帮我解决这个问题吗?

我的下一个问题是,当我的线程写入同一阵列的不同地址位置时,我是否需要对它们使用锁定?

相关代码

main.cpp的内容

#include <stdio.h>
#include <stdlib.h>
#include "a.cpp"


int *array;

int main() {
   array = new int[393216];
   foo(array);
   return 0;
}

a.cpp的内容

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


struct a {
   int array[];
};

pthread_mutex_t mutex;

void *funcname (void* param) {
    struct a *data = (struct a*) param;
    int index = 33779;
    pthread_mutex_lock(&mutex);
    data->array[index] = 1;
    pthread_mutex_unlock(&mutex);
}


void foo (int array[]) {
    struct a* data[2];
    pthread_mutex_init(&mutex, NULL);

    pthread_t threads[2];

    for ( int i = 0 ; i < 2 ; ++i) {
        data[i] = (struct a*)malloc (sizeof(struct a));
        *data[i]->array = *array;
        pthread_attr_t attr;
        pthread_attr_init(&attr);

        pthread_create (&threads[i], NULL, funcname, data[i]);

    }
    for ( int i = 0 ; i< 2; ++i)
        pthread_join( threads[i], NULL );

    }

提前致谢!

1 个答案:

答案 0 :(得分:0)

*data[i]->array = *array;

只需复制第一个元素即可。 你可以用

struct a { int* array; }

然后,只需复制指针。

data[i]->array = array;