Нет, вам не нужно создавать их динамически. Вы можете использовать статический массив, вам просто нужно настроить их все, прежде чем использовать. Ты можешь сделать:
#define NUM_THREADS 5
static pthread_mutex_t mutexes[NUM_THREADS] = {
PTHREAD_MUTEX_INITIALIZER,
PTHREAD_MUTEX_INITIALIZER,
PTHREAD_MUTEX_INITIALIZER,
PTHREAD_MUTEX_INITIALIZER,
PTHREAD_MUTEX_INITIALIZER
};
который подвержен ошибкам, если вы когда-либо меняете NUM_THREADS
, хотя это можно исправить с помощью чего-то вроде:
static pthread_mutex_t mutexes[] = {
PTHREAD_MUTEX_INITIALIZER,
PTHREAD_MUTEX_INITIALIZER,
PTHREAD_MUTEX_INITIALIZER,
PTHREAD_MUTEX_INITIALIZER,
PTHREAD_MUTEX_INITIALIZER
};
#define NUM_THREADS (sizeof(mutexes)/sizeof(*mutexes))
Кроме того, вы можете сделать это с помощью кода, например:
#define NUM_THREADS 5
static pthread_mutex_t mutexes[NUM_THREADS];
// Other stuff
int main (void) {
for (int i = 0; i < NUM_THREADS; i++)
pthread_mutex_init(&mutexes[i], NULL);
// Now you can use them safely.
return 0;
}
Во всех этих случаях они правильно настроены, прежде чем пытаться их использовать. На самом деле, я бы сделал это задолго до того, как вы приступите к любому многопоточному процессу, но это просто я параноик.
person
paxdiablo
schedule
28.02.2011