開発環境
- OS: macOS High Sierra - Apple
- IDE(統合開発環境): Xcode - Apple
- プログラミング言語: C
Head First C ―頭とからだで覚えるCの基本 (David Griffiths (著)、Dawn Griffiths (著)、中田 秀基 (監修)、木下 哲也 (翻訳)、オライリージャパン)の12章(スレッド - 並列の世界)、長いエクササイズ(p. 516)を取り組んでみる。
長いエクササイズ(p. 516)
//
// main.c
// sample
//
// Created by kamimura on 2018/03/12.
// Copyright © 2018 kamimura. All rights reserved.
//
#include <stdio.h>
#include <pthread.h>
int beers = 2000000;
pthread_mutex_t beers_lock = PTHREAD_MUTEX_INITIALIZER;
void *drink_lots1(void *a) {
pthread_mutex_lock(&beers_lock);
for (int i = 0; i < 100000; i++) {
beers--;
}
pthread_mutex_unlock(&beers_lock);
printf("beers = %i\n", beers);
return NULL;
}
void *drink_lots2(void *a) {
for (int i = 0; i < 100000; i++) {
pthread_mutex_lock(&beers_lock);
beers--;
pthread_mutex_unlock(&beers_lock);
}
printf("beers = %i\n", beers);
return NULL;
}
int main(int argc, const char * argv[]) {
puts("バージョンA(drink_lots1)");
pthread_t threads[20];
printf("壁にはビールが%i本\n%i本のビール\n", beers, beers);
for (int t = 0; t < 20; t++) {
pthread_create(&threads[t], NULL, drink_lots1, NULL);
}
void *result;
for (int t = 0; t < 20; t++) {
pthread_join(threads[t], &result);
}
printf("現在、壁にはビールが%i本あります。\n", beers);
beers = 2000000;
puts("バージョンB(drink_lots2)");
printf("壁にはビールが%i本\n%i本のビール\n", beers, beers);
for (int t = 0; t < 20; t++) {
pthread_create(&threads[t], NULL, drink_lots2, NULL);
}
for (int t = 0; t < 20; t++) {
pthread_join(threads[t], &result);
}
printf("現在、壁にはビールが%i本あります。\n", beers);
return 0;
}
入出力結果(Terminal)
バージョンA(drink_lots1) 壁にはビールが2000000本 2000000本のビール beers = 1900000 beers = 1800000 beers = 1700000 beers = 1600000 beers = 1500000 beers = 1400000 beers = 1300000 beers = 1200000 beers = 1100000 beers = 1000000 beers = 900000 beers = 800000 beers = 700000 beers = 600000 beers = 500000 beers = 400000 beers = 300000 beers = 200000 beers = 100000 beers = 0 現在、壁にはビールが0本あります。 バージョンB(drink_lots2) 壁にはビールが2000000本 2000000本のビール beers = 36676 beers = 31 beers = 25 beers = 21 beers = 20 beers = 14 beers = 13 beers = 12 beers = 11 beers = 10 beers = 9 beers = 7 beers = 7 beers = 6 beers = 5 beers = 4 beers = 3 beers = 2 beers = 1 beers = 0 現在、壁にはビールが0本あります。 Program ended with exit code: 0
0 コメント:
コメントを投稿