久久精品国产亚洲高清|精品日韩中文乱码在线|亚洲va中文字幕无码久|伊人久久综合狼伊人久久|亚洲不卡av不卡一区二区|精品久久久久久久蜜臀AV|国产精品19久久久久久不卡|国产男女猛烈视频在线观看麻豆

    1. <style id="76ofp"></style>

      <style id="76ofp"></style>
      <rt id="76ofp"></rt>
      <form id="76ofp"><optgroup id="76ofp"></optgroup></form>
      1. 千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機構(gòu)

        手機站
        千鋒教育

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

        千鋒教育

        掃一掃進入千鋒手機站

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

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

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

        Python 性能剖分工具

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

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

        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()

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

        if__name__=="__main__":

        importprofile

        profile.run("foo()")

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

        因為上述方法需要修改foo.py文件,所以我們通常更傾向于使用無需修改源文件的方法——就是在命令行中用應(yīng)用python的–m參數(shù)來執(zhí)行profile:

        python–mprofilefoo.py

        除了可以使用profile模塊外,還可以使用cProfile模塊。cProfile由C語言實現(xiàn),是剖分代價更低的剖分器,有和profile模塊相同的接口,但只能用于2.5或以上版本。Python另一個內(nèi)置的剖分器是hotshot,但是hotshot模塊已經(jīng)不再推薦使用,因為將來它可能會被移出標準庫。

        pstats

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

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

        importpstats

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

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

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

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

        ncalls’

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

        ‘cumulative’

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

        ‘nfl’

        Name/file/line

        ‘time’

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

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

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

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

        聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
        10年以上業(yè)內(nèi)強師集結(jié),手把手帶你蛻變精英
        請您保持通訊暢通,專屬學(xué)習(xí)老師24小時內(nèi)將與您1V1溝通
        免費領(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
        交口县| 沅江市| 宝山区| 晋江市| 固原市| 西平县| 宁阳县| 公主岭市| 沁源县| 镇江市| 怀安县| 昌图县| 南平市| 瑞金市| 光山县| 红河县| 新竹市| 建始县| 尤溪县| 隆子县| 龙胜| 望江县| 格尔木市| 宜章县| 响水县| 景洪市| 都兰县| 彰武县| 西畴县| 鱼台县| 开江县| 莱州市| 连江县| 鄂伦春自治旗| 宁强县| 景洪市| 三门县| 井陉县| 嘉禾县| 普格县| 河西区|