麻豆黑色丝袜jk制服福利网站-麻豆精品传媒视频观看-麻豆精品传媒一二三区在线视频-麻豆精选传媒4区2021-在线视频99-在线视频a

千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機(jī)構(gòu)

手機(jī)站
千鋒教育

千鋒學(xué)習(xí)站 | 隨時(shí)隨地免費(fèi)學(xué)

千鋒教育

掃一掃進(jìn)入千鋒手機(jī)站

領(lǐng)取全套視頻
千鋒教育

關(guān)注千鋒學(xué)習(xí)站小程序
隨時(shí)隨地免費(fèi)學(xué)習(xí)課程

當(dāng)前位置:首頁  >  技術(shù)干貨  > Python 性能剖分工具

Python 性能剖分工具

來源:千鋒教育
發(fā)布人:xqq
時(shí)間: 2023-11-07 10:05:09 1699322709

眼看著項(xiàng)目即將完成,卻被測(cè)試人員告知沒有通過性能測(cè)試,這種情況在開發(fā)中屢見不鮮。接下來的工作就是加班加點(diǎn)地找出性能瓶頸,然后進(jìn)行優(yōu)化,再進(jìn)行性能測(cè)試,如此這般周而復(fù)始直到通過性能測(cè)試。盡管豐富的工作經(jīng)驗(yàn)有助于性能優(yōu)化,但只有科學(xué)地應(yīng)用工具才能在最短的時(shí)間內(nèi)找出最佳優(yōu)化粒度的瓶頸代碼段,達(dá)到事半功倍的效果。

profile、cProfile與hotshot

Python內(nèi)置了豐富的性能優(yōu)化工具來幫助我們定位性能瓶頸,如:profile、cProfile和hotshot。它們易于使用,而且有完備的支持文檔可供參考。下面以最常用的profile模塊為例來說明它們的使用方法,假定要剖分的腳本文件為foo.py,它的內(nèi)容如下:

deffoo():

sum=0

foriinrange(100):

sum+=i

returnsum

if__name__=="__main__":

foo()

對(duì)foo.py進(jìn)行性能剖分的方法之一是修改foo.py里的if程序塊,引入profile模塊:

if__name__=="__main__":

importprofile

profile.run("foo()")

然后執(zhí)行foo.py即可完成性能剖分,剖分結(jié)果將以文本報(bào)表的形式打印到標(biāo)準(zhǔn)輸出。

因?yàn)樯鲜龇椒ㄐ枰薷膄oo.py文件,所以我們通常更傾向于使用無需修改源文件的方法——就是在命令行中用應(yīng)用python的–m參數(shù)來執(zhí)行profile:

python–mprofilefoo.py

除了可以使用profile模塊外,還可以使用cProfile模塊。cProfile由C語言實(shí)現(xiàn),是剖分代價(jià)更低的剖分器,有和profile模塊相同的接口,但只能用于2.5或以上版本。Python另一個(gè)內(nèi)置的剖分器是hotshot,但是hotshot模塊已經(jīng)不再推薦使用,因?yàn)閷硭赡軙?huì)被移出標(biāo)準(zhǔn)庫。

pstats

無論使用哪個(gè)剖分器,它的剖分?jǐn)?shù)據(jù)都可以保存到二進(jìn)制文件,如foo.prof。分析和查看剖分結(jié)果文件需要使用pstats模塊,它極具伸縮性,可以輸出形式多樣的文本報(bào)表,是文本界面下不可或缺的工具。

使用pstats分析剖分結(jié)果很簡(jiǎn)單,幾行代碼就可以了:

importpstats

p=pstats.Stats("foo.prof")

p.sort_stats("time").print_stats()

運(yùn)行上述腳本將輸出結(jié)果為按函數(shù)內(nèi)部運(yùn)行時(shí)間(不計(jì)調(diào)用子函數(shù)的時(shí)間)長(zhǎng)短排序的報(bào)表。

sort_stats()方法是pstats.Stats最重要的方法之一,它用以對(duì)剖分?jǐn)?shù)據(jù)進(jìn)行排序。sort_stats()接受一個(gè)字符串參數(shù),這個(gè)字符串標(biāo)識(shí)了排序的字段,常用的可選的參數(shù)及其意義如下:

ncalls’

被調(diào)用次數(shù)

‘cumulative’

函數(shù)運(yùn)行的總時(shí)間

‘nfl’

Name/file/line

‘time’

函數(shù)內(nèi)部運(yùn)行時(shí)間(不計(jì)調(diào)用子函數(shù)的時(shí)間)

除了sort_stats()外,pstats.Stats還有print_callees()和print_callers()方法用以輸出指定函數(shù)所調(diào)用的函數(shù)和調(diào)用過指定函數(shù)的函數(shù)。

除了編編程接口外,pstats還提供了友好的命令行交互環(huán)境,在命令行執(zhí)行python–mpstats就可以進(jìn)入交互環(huán)境,在交互環(huán)境里可以使用read/add指令讀入/加載剖分結(jié)果文件,stats指令用以查看報(bào)表,callees和callers指令用以查看特定函數(shù)的被調(diào)用者和調(diào)用者。下圖是pstats的截圖,標(biāo)識(shí)了它的基本使用方法

以上內(nèi)容為大家介紹了Python性能剖分工具,希望對(duì)大家有所幫助,如果想要了解更多Python相關(guān)知識(shí),請(qǐng)關(guān)注IT培訓(xùn)機(jī)構(gòu):千鋒教育。http://www.dietsnews.net/

聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
10年以上業(yè)內(nèi)強(qiáng)師集結(jié),手把手帶你蛻變精英
請(qǐng)您保持通訊暢通,專屬學(xué)習(xí)老師24小時(shí)內(nèi)將與您1V1溝通
免費(fèi)領(lǐng)取
今日已有369人領(lǐng)取成功
劉同學(xué) 138****2860 剛剛成功領(lǐng)取
王同學(xué) 131****2015 剛剛成功領(lǐng)取
張同學(xué) 133****4652 剛剛成功領(lǐng)取
李同學(xué) 135****8607 剛剛成功領(lǐng)取
楊同學(xué) 132****5667 剛剛成功領(lǐng)取
岳同學(xué) 134****6652 剛剛成功領(lǐng)取
梁同學(xué) 157****2950 剛剛成功領(lǐng)取
劉同學(xué) 189****1015 剛剛成功領(lǐng)取
張同學(xué) 155****4678 剛剛成功領(lǐng)取
鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
董同學(xué) 138****2867 剛剛成功領(lǐng)取
周同學(xué) 136****3602 剛剛成功領(lǐng)取
相關(guān)推薦HOT
Python工具庫之collections

collection在英文當(dāng)中有容器的意思,所以顧名思義,這是一個(gè)容器的集合。這個(gè)庫當(dāng)中的容器很多,有一些不是很常用,本篇文章選擇了其中最常用的...詳情>>

2023-11-07 12:54:22
Python中heapq與優(yōu)先隊(duì)列

今天的文章來介紹Python當(dāng)中一個(gè)蠻有用的庫——heapq。heapq的全寫是heapqueue,是堆隊(duì)列的意思。這里的堆和隊(duì)列都是數(shù)據(jù)結(jié)構(gòu),在后序的文章當(dāng)...詳情>>

2023-11-07 12:25:33
python閉包的定義

如果在一個(gè)內(nèi)部函數(shù)中,引用了外部非全局作用域中的變量,那么這個(gè)內(nèi)部函數(shù)就被認(rèn)為是閉包(closure)。在一些語言中,在函數(shù)中可以(嵌套)定義另...詳情>>

2023-11-07 11:53:09
Python中可以hash的數(shù)據(jù)類型

在Python中,僅僅只有不可變數(shù)據(jù)類型可以被hash,然而每個(gè)自定義的對(duì)象在Python中都可以被hash,默認(rèn)的他們的hash值是由他們的id派生的。也就意...詳情>>

2023-11-07 11:49:33
Python學(xué)習(xí)的三個(gè)階段

首先,在當(dāng)前諸多的計(jì)算機(jī)編程語言當(dāng)中,Python語言確實(shí)算是比較簡(jiǎn)單易學(xué)的一種,即使沒有任何編程基礎(chǔ)的人,也完全可以通過自學(xué)來入門,但是要...詳情>>

2023-11-07 11:27:57
主站蜘蛛池模板: 国产一区小可爱原卡哇伊| 恸哭の女教师大桥未久| 天天操天天干天天干| 大女小娟二女小妍| 多人乱p欧美在线观看| 日本电影在线观看免费影院| 国产三级在线观看免费| 在线观看v片| 99在线精品免费视频九九视 | 里番肉片h排行榜| 国产999| 大学寝室沈樵无删减| 亚洲国产精品va在线观看麻豆| 美女羞羞视频免费网站| а√天堂中文在线官网| 四虎4hutv永久在线影院| 欧美日韩一区二区三区自拍| 男插女下体视频| 2019国产开嫩苞视频| 夜夜揉揉日日人人视频| 色婷婷视频| 国产综合久久久久| 日韩伦理片电影在线免费观看 | 日产精品卡二卡三卡四卡乱码视频 | 日本动漫打扑克动画片樱花动漫| 精品无码久久久久久国产| 永久黄网站色视频免费观看| 男人桶女人j的视频在线观看| 欧美va天堂在线电影| 久久99国产精品久久99果冻传媒| 视频在线免费观看资源| 国产开嫩苞实拍在线播放视频| av线上观看| 波多野结衣与黑人| 老子影院午夜伦手机不卡6080| 国产一级做a爰片在线| 小嫩妇又紧又嫩好紧视频| 伊人影院在线视频| 香港一级毛片免费看| 男人操女人免费视频| 福利视频亚洲|