開発環境
- OS X Lion - Apple(OS)
- TextWrangler(Text Editor) (BBEditの機能制限無料版、light版)
- Script言語:Ruby
『初めてのプログラミング 第2版』(Chris Pine 著、長尾 高弘 訳、オライリー・ジャパン、2010年、ISBN978-4-87311-469-9)の14章(ブロックとプロック), 14.4(練習問題)よりよいブロファイリングを解いてみる。
その他参考書籍
- 『プログラミング言語 Ruby』David Flanagan, まつもと ゆきひろ 著 、卜部 昌平 監訳、長尾 高弘 訳、オライリー・ジャパン、2009年、ISBN978-4-87311-394-4)
よりよいブロファイリング
コード(TextWrangler)
#!/usr/bin/env ruby #encoding: utf-8 def profile block_description, &block on_off = false if on_off start_time = Time.new block.call duration = Time.new - start_time puts "#{block_description}: #{duration}秒" else block.call end end profile '25000回の倍化' do number = 1 25000.times do number += number end puts "#{number.to_s.length}桁" end profile '百万までのカウント' do number = 0 1000000.times do number += 1 end end
入出力結果(Terminal)
$ ./ruby_program.rb 7526桁 25000回の倍化: 0.0926950000000001秒 百万までのカウント: 0.255456秒 $ ./ruby_program.rb 7526桁 $
最初の結果がプロファイルングをオン、2回目はオフ。
本書を続けつつ、上記の本を入手したらそっちに切り替え。
0 コメント:
コメントを投稿