開発環境
- OS X Mavericks - Apple(OS)
- Emacs (CUI)、BBEdit - Bare Bones Software, Inc. (GUI) (Text Editor)
- Python 3.4 (プログラミング言語)
Head First C ―頭とからだで覚えるCの基本(David Griffiths (著)、Dawn Griffiths (著) 中田 秀基(監訳)(翻訳)、木下 哲也 (翻訳)、オライリージャパン)の12章(スレッド: 並列の世界)、長いエクササイズ(p.516)をpythonで考えてみる。
長いエクササイズ(p.516)
コード(BBEdit, Emacs)
sample516_a.py
#!/usr/bin/env python3 #-*- coding: utf-8 -*- import sys import threading threads = [] beers = 2000000 lock = threading.Lock() def error(msg): print("{0}: {1}".format(msg, err), file=sys.stderr) sys.exit(1) def drink_lots(): global beers lock.acquire() for n in range(100000): beers -= 1 lock.release() print('beers =', beers) print('壁にはビールが{0}本\n{0}本のビール'.format(beers)) for t in range(20): thread = threading.Thread(target=drink_lots) try: thread.start() except Exception as err: error(err) threads.append(thread) for t in threads: try: t.join() except Exception as err: error(err) print('現在、壁にはビールが{0}本あります。'.format(beers))
sample516_b.py
#!/usr/bin/env python3 #-*- coding: utf-8 -*- import sys import threading threads = [] beers = 2000000 lock = threading.Lock() def error(msg): print("{0}: {1}".format(msg, err), file=sys.stderr) sys.exit(1) def drink_lots(): global beers for n in range(100000): lock.acquire() beers -= 1 lock.release() print('beers =', beers) print('壁にはビールが{0}本\n{0}本のビール'.format(beers)) for t in range(20): thread = threading.Thread(target=drink_lots) try: thread.start() except Exception as err: error(err) threads.append(thread) for t in threads: try: t.join() except Exception as err: error(err) print('現在、壁にはビールが{0}本あります。'.format(beers))
入出力結果(Terminal, IPython)
$ ./sample516_a.py 壁にはビールが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本あります。 $ ./sample516_b.py 壁にはビールが2000000本 2000000本のビール beers = 1300579 beers = 819749 beers = 674229 beers = 454050 beers = 362911 beers = 355916 beers = 299044 beers = 196702 beers = 177823 beers = 157745 beers = 75382 beers = 72627 beers = 70823 beers = 63248 beers = 49209 beers = 31814 beers = 10105 beers = 0 beers = 844 beers = 21858 現在、壁にはビールが0本あります。 $ time ./sample516_a.py 壁にはビールが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本あります。 real 0m0.347s user 0m0.329s sys 0m0.019s $ time ./sample516_b.py 壁にはビールが2000000本 2000000本のビール beers = 1162786 beers = 472821 beers = 444107 beers = 434637 beers = 430698 beers = 379902 beers = 379420 beers = 301852 beers = 252605 beers = 179233 beers = 175693 beers = 151523 beers = 148012 beers = 107366 beers = 73565 beers = 66355 beers = 42860 beers = 32839 beers = 56482 beers = 0 現在、壁にはビールが0本あります。 real 0m19.568s user 0m6.780s sys 0m22.330s $
0 コメント:
コメントを投稿