我正在使用一个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用户,因此我猜代码或多或少都可以。
谢谢!
答案 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);
}