Pthreads的奇怪行为

时间:2013-05-04 17:26:36

标签: c pthreads

我已经编写了一个使用pthreads进行处理的程序。程序每次运行都会产生奇怪的行为。 为简单起见,我评论了处理线。错误仍然存​​在。 这是代码(相关部分):

pthread_t Thread[THREAD_NUM];
pthread_barrier_t BarrierStart;
pthread_rwlock_t DebugLock;

void T2_FFT_Comp(void)
{
    int Return;
    T2_FFT_Comp_Input ThreadInput;
    Return = pthread_rwlock_init(&DebugLock,NULL);
    if (Return)
    {
        cout << endl << "Error while creating lock ";
    }
    pthread_barrier_init(&BarrierStart,NULL,THREAD_NUM);
    for(int i = 0;i < THREAD_NUM;i++)
    {
        ThreadInput.Start =  i*ThreadDataSize;                     //struct is relevant to processing part
        ThreadInput.ThreadNum = i;
        Return = pthread_create(&Thread[i],NULL,T2_FFT_Comp_ThreadFn,(void *)&ThreadInput);
        pthread_rwlock_wrlock(&DebugLock);
        cout << endl << "creating thread number " << i;
        pthread_rwlock_unlock(&DebugLock);
        if (Return)
        {
            cout << endl << "Error while creating thread #" << i;
        }
    }
    for (int i = 0;i<THREAD_NUM;i++)
    {
        Return = pthread_join(Thread[i],NULL);
        if (Return)
        {
            pthread_rwlock_wrlock(&DebugLock);
            cout << endl << "Error while joining thread Number : " << i;
            pthread_rwlock_unlock(&DebugLock);
        }
    }
    pthread_rwlock_destroy(&DebugLock);
    return;
}

void *T2_FFT_Comp_ThreadFn(void *input)
{
    int InputStart = ((T2_FFT_Comp_Input *)input)->Start;
    int ThreadID = ((T2_FFT_Comp_Input *)input)->ThreadNum;
    int Return;
    pthread_rwlock_wrlock(&DebugLock);
    cout << endl << "Thread number : " << ThreadID << " created";
    pthread_rwlock_unlock(&DebugLock);
    pthread_exit(NULL);
}

该程序产生奇怪的行为。有时它是分段错误。有时它会像这样产生输出

creating thread number 0
Thread number :0 created
creating thread number 1
creating thread number 2
creating thread number 3
Joining Thread Number : 0
Thread number :3 created
Thread number :3 created
Thread number :3 created

创建的线程数有时是对还是错。有时也有多条连线。 我不明白为什么会这样。

1 个答案:

答案 0 :(得分:2)

将名为ThreadInput的同一局部变量的地址传递给每个线程。这意味着每个线程都在访问,不同步,相同的变量。这是竞争条件,是未定义的行为。即使它不是竞争条件,也不是预期的行为。要更正,请将不同的实例传递给每个线程而不是相同的(通过使用T2_FFT_Comp_Input[THREAD_NUM]数组并将元素的地址仅传递给一个线程,或者通过动态分配T2_FFT_Comp_Input并将其传递给线程并使用线程free()