欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python 實(shí)現(xiàn)一個(gè)計(jì)時(shí)器

 更新時(shí)間:2020年07月28日 14:50:10   作者:David Beazley  
這篇文章主要介紹了Python 實(shí)現(xiàn)一個(gè)計(jì)時(shí)器的方法,文中講解非常細(xì)致,代碼幫助大家更好的理解和學(xué)習(xí),感興趣的朋友可以了解下

問(wèn)題

你想記錄程序執(zhí)行多個(gè)任務(wù)所花費(fèi)的時(shí)間

解決方案

time 模塊包含很多函數(shù)來(lái)執(zhí)行跟時(shí)間有關(guān)的函數(shù)。 盡管如此,通常我們會(huì)在此基礎(chǔ)之上構(gòu)造一個(gè)更高級(jí)的接口來(lái)模擬一個(gè)計(jì)時(shí)器。例如:

import time

class Timer:
  def __init__(self, func=time.perf_counter):
    self.elapsed = 0.0
    self._func = func
    self._start = None

  def start(self):
    if self._start is not None:
      raise RuntimeError('Already started')
    self._start = self._func()

  def stop(self):
    if self._start is None:
      raise RuntimeError('Not started')
    end = self._func()
    self.elapsed += end - self._start
    self._start = None

  def reset(self):
    self.elapsed = 0.0

  @property
  def running(self):
    return self._start is not None

  def __enter__(self):
    self.start()
    return self

  def __exit__(self, *args):
    self.stop()

這個(gè)類定義了一個(gè)可以被用戶根據(jù)需要啟動(dòng)、停止和重置的計(jì)時(shí)器。 它會(huì)在 elapsed 屬性中記錄整個(gè)消耗時(shí)間。 下面是一個(gè)例子來(lái)演示怎樣使用它:

def countdown(n):
  while n > 0:
    n -= 1

# Use 1: Explicit start/stop
t = Timer()
t.start()
countdown(1000000)
t.stop()
print(t.elapsed)

# Use 2: As a context manager
with t:
  countdown(1000000)

print(t.elapsed)

with Timer() as t2:
  countdown(1000000)
print(t2.elapsed)

討論

本節(jié)提供了一個(gè)簡(jiǎn)單而實(shí)用的類來(lái)實(shí)現(xiàn)時(shí)間記錄以及耗時(shí)計(jì)算。 同時(shí)也是對(duì)使用with語(yǔ)句以及上下文管理器協(xié)議的一個(gè)很好的演示。

在計(jì)時(shí)中要考慮一個(gè)底層的時(shí)間函數(shù)問(wèn)題。一般來(lái)說(shuō), 使用 time.time() time.clock() 計(jì)算的時(shí)間精度因操作系統(tǒng)的不同會(huì)有所不同。 而使用 time.perf_counter() 函數(shù)可以確保使用系統(tǒng)上面最精確的計(jì)時(shí)器。

上述代碼中由 Timer 類記錄的時(shí)間是鐘表時(shí)間,并包含了所有休眠時(shí)間。 如果你只想計(jì)算該進(jìn)程所花費(fèi)的CPU時(shí)間,應(yīng)該使用 time.process_time() 來(lái)代替:

t = Timer(time.process_time)
with t:
  countdown(1000000)
print(t.elapsed)

time.perf_counter() time.process_time() 都會(huì)返回小數(shù)形式的秒數(shù)時(shí)間。 實(shí)際的時(shí)間值沒(méi)有任何意義,為了得到有意義的結(jié)果,你得執(zhí)行兩次函數(shù)然后計(jì)算它們的差值。

以上就是Python 實(shí)現(xiàn)一個(gè)計(jì)時(shí)器的詳細(xì)內(nèi)容,更多關(guān)于Python 計(jì)時(shí)器的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

最新評(píng)論