私は、学校プロジェクトのいくつかの数値にいくつかの数学を行うプログラムを作っていました。私は10個のスレッドを持っているが、42個のアイテムが処理されているとすれば、それらがすべてのアイテムを均等に処理し、均等な量のジョブを取るようにしたい。私はPOSIXのpthreadライブラリを使っていますが、それはmutexと何か関係がありますが、私は完全にはわかりません。スレッド間の処理を分割しますか? (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