av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

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

瀏覽:82日期:2022-07-16 09:31:23

問題

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

解決方案

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

import timeclass 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è)例子來演示怎樣使用它:

def countdown(n): while n > 0: n -= 1# Use 1: Explicit start/stopt = Timer()t.start()countdown(1000000)t.stop()print(t.elapsed)# Use 2: As a context managerwith t: countdown(1000000)print(t.elapsed)with Timer() as t2: countdown(1000000)print(t2.elapsed)

討論

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

在計(jì)時(shí)中要考慮一個(gè)底層的時(shí)間函數(shù)問題。一般來說, 使用 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() 來代替:

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

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

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

標(biāo)簽: Python 編程
相關(guān)文章:
主站蜘蛛池模板: 在线91| 亚洲最大网站 | 99久久精品国产一区二区三区 | 久久精品一二三 | 欧美a级黄色片 | 天天躁日日躁狠狠很躁 | 一区二区三区四区免费视频 | 91久久久久久久久 | 国产一级特黄 | 日韩久久久| 亚洲免费网站 | 天堂免费av| 欧美人xxxx | 四虎免费视频 | 日本色综合 | 国产h视频在线观看 | 精品国产欧美 | 免费午夜视频 | 日韩精品一区在线观看 | 欧美日韩精品 | 69人人| 亚洲最新视频 | 特级毛片爽www免费版 | 色女人影院 | 欧美黄色片网站 | 天天操天天干天天爽 | 国产成人精品一区二区三区在线观看 | 免费一级a毛片夜夜看 | 国产精品免费在线播放 | 日本中文字幕在线播放 | 国产精品久久久久久中文字 | www精品| 成人在线免费视频观看 | 黄色片视频 | 中文字幕丰满人伦在线 | 国产成人一区二区 | 免费看黄色大片 | 三级视频在线观看 | 成年人黄色 | 欧美一区二区在线 | 嫩草国产 |