Я создавал программу для некоторых математических вычислений для некоторых номеров для школьного проекта. Скажем, у меня есть 10 потоков, но 42 элемента для обработки, я хочу, чтобы они обрабатывали все элементы равномерно и занимали ровное количество заданий. Я использую POSIX pthread library, я знаю, что это связано с мьютексом, но я не совсем уверен.Разделение между потоками? (pthread)
Вот упрощенный пример того, что я делаю, однако я хочу равномерно сбалансировать рабочую нагрузку.
#include <stdio.h>
#include <stdlib.h>
#include <pthread.h>
int numbers = { 1, 78, 19, 49, 14, 1, 14. 19, 57, 15, 95, 19, 591, 591 };
void* method() {
for(size_t i = 0; i < 14; i++) {
printf("%d\n", (numbers[i] * 2));
}
}
int main(int argc, char const *argv[]) {
pthread_t th[10];
for (size_t i = 0; i < 10; i++) {
pthread_create(&th[i], NULL, method, NULL);
}
return 0;
}
Это также может зависеть от типа процесса и _items_, который необходимо обработать. В любом случае, обязательно создайте и передайте указатели на элементы в качестве аргументов потока - аргумент # 4 на 'pthread_create()'. – user3078414