time.time()
Linuxでは、現在の時刻をus = 1/1000 ms
正確に生成しているようです。
これを使用して、関数をms
正確にプロファイリングできますか?
func_start = time.time() * 1000
#run something inbetween
print 'Function finishes in: %.3f ms' % ((time.time() * 1000) - func_start)
いいえ、そのように精度を上げることはありません。あなたも同様に行うことができます:
func_start = time.time()
print 'Function finishes in: %.3f ms' % ((time.time() - func_start) * 1000)
ただし、関数のパフォーマンスを正確に測定するには、OSのスケジューリング、同時発生するディスクフラッシュ割り込みなどの影響を取り除くために、関数を数回再実行する必要があります。
プラットフォームで可能な限り正確なタイミング方法については、timeit
モジュールを使用するか、少なくともそのdefault_timer()
機能を再利用してください。