pthreadを使用して文字列「スレッド0」から「スレッド4」を出力するコードを記述します。
これが私のコードです:
ケース1:
#include <stdio.h>
#include <stdlib.h>
#include <pthread.h>
void *print_message_function(void* parameter) {
long *i = (long *)parameter;
printf("Thread %ld\n", *i);
pthread_exit(0);
}
int main(int argc, char *argv[]) {
pthread_t threads[5];
long i = 0;
for (i = 0; i < 5; i++) {
pthread_create(&threads[i], 0, print_message_function, (void *)&i);
}
pthread_exit(NULL);
}
しかし、結果は次のとおりです。
Thread 2
Thread 3
Thread 3
Thread 4
Thread 5
また:
Thread 0
Thread 0
Thread 0
Thread 0
Thread 0
もう一度実行すると変更されました。したがって、渡した値が(2〜5)またはすべて(0)または.....(多くの場合)である理由がわかりません。私が渡した引数は0から4だと思います。
ケース2:
新しいコードに変更すると:
#include <stdio.h>
#include <stdlib.h>
#include <pthread.h>
void *print_message_function(void *parameter);
int main(int argc, char *argv[]) {
pthread_t threads[5];
int i = 0;
for (i = 0; i < 5; i++) {
char *msg = (char*)malloc(sizeof(char));
sprintf(msg, "Thread %d", i);
pthread_create(&threads[i], 0, print_message_function, (void *)msg);
}
}
void *print_message_function(void *parameter) {
printf("%s\n", (char *)parameter);
}
結果は次のとおりです。
Thread 1
Thread 0
Thread 3
Thread 2
Thread 4
Thread 4
これは、ループが6回実行されることを意味します。なんで?