具有不同用户的信号量不起作用

时间:2013-10-05 23:29:08

标签: c semaphore

我正在使用一个c-项目,它使用信号量同时处理相同的功能。当我在linux上运行它时,在root用户下,它运行得很完美。但是如果我在另一个用户上运行它,脚本就不会被执行,它会在信号量数组中留下一个信号量。有人知道这个问题的解决方案吗?

这是我的代码:

int main(int argC, char* argv[]) {

    pthread_t thr[argC-1];
    int indexes[argC-1];
    int i,j;
    for(j=0; j<(argC-1); j++) {

        indexes[j] = atoi(argv[j+1]);
        pthread_create (&thr[j], NULL, (int *) &stabtest, (void *) &indexes[j]);  
    }

    sem_init(&mutex, 0, 1); 

    for(j=0; j<(argC-1); j++) pthread_join(thr[j], NULL);

    // Destroy semaphore
    sem_destroy(&mutex);

    // Exit
    exit(0);   
}

int stabtest(void *ptr) {

    sem_wait(&mutex); // down semaphore

    // Other code ...

    sem_post(&mutex); // up semaphore 
    pthread_exit(0);  // exit thread 

}

这个代码我实际上是在互联网上找到的,因为我没有使用信号量的经验。所以我不确定这个代码是否是同时并行运行该函数的代码。但它适用于root用户,因此我猜代码或多或少都可以。

谢谢!

1 个答案:

答案 0 :(得分:0)

如果这是您正在使用的代码,那么您认为发生的任何事情都不会发生。权限应该对您使用的信号量没有影响。并且没有信号量数组,您使用的是单个信号量。

你似乎对命令行参数有一个不稳定的把握。它们是字符串的数组指针。 argc是参数的数量。总会有至少1个argv,argv [0],这是程序名称。请不要重命名argc。每个人都知道argc是什么。重命名它只会让人烦恼。

启动线程然后然后初始化信号量。那是个问题。

pthread 的启动函数具有签名void* stabtest(void *ptr)。你的是int stabtest(void *ptr)而你正试图摆脱错误。不要那样做。如果你想从一个线程返回一些东西,你可以通过用作pthread_create中第四个parm的void ptr来完成它。也就是说,分配一些内存,在pthread_create中传递它,在线程中做任何你需要的东西来改变指向的信息,然后从线程返回相同的void ptr。当您执行pthread_join时,您可以在pthread_join中访问返回指向第二个参数中数据的指针。

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

sem_t mutex;

void* stabtest(void *ptr)
{
    sem_wait(&mutex); // down semaphore
    printf("in thread %lu...\n", pthread_self());
    sem_post(&mutex); // up semaphore

    pthread_exit(0);  // exit thread
}

int main(int argc, char* argv[])
{
    if (argc != 2)
    {
        printf("usage: %s numThread\n", argv[0]);
        exit(1);
    }

    int maxThreads = atoi(argv[1]);

    pthread_t thr[maxThreads];
    int indexes[maxThreads];
    int i, j;

    sem_init(&mutex, 0, 1);

    for (j = 0; j < maxThreads; j++)
        pthread_create (&thr[j], NULL, stabtest, NULL);

    for (j = 0; j < maxThreads; j++)
        pthread_join(thr[j], NULL);

    // Destroy semaphore
    sem_destroy(&mutex);

    // Exit
    exit(0);
}