gprof-Linux下程式的效能最佳化工具

來源:互聯網
上載者:User

 

我們在寫程式,特別是嵌入式程式的時候,通常需要對程式的效能進行分析,以便程式能夠更快更好地運行,達到即時(real-time)的目的。如果程式很大,分析起來就很困難。如果有個工具能夠自動進行程式的效能分析,那就最好了。這裡介紹一種Linux下程式的Profiling工具---

GNU gprof。

GNU gprof能夠列印出程式運行中各個函數消耗的時間,可以協助程式員找出眾多函數中耗時最多的函數。產生程式運行時候的函數調用關係,包括調用次數,可以協助程式員剖析器的運行流程。有 了函數的調用關係,這會讓開發人員大大提高工作效率,不用費神地去一點點找出程式的運行流程,這對小程式來說可能效果不是很明顯,但對於有幾萬,幾十萬代 碼量的工程來說,效率是毋庸置疑的!而且這個功能對於維護舊代碼或者是分析Open Source來說那是相當誘人的,有了調用圖,對程式的運行架構也就有了一個大體瞭解,知道了程式的“骨架“,分析它也就不會再那麼茫然,尤其是對自己不
熟悉的代碼和Open Source。

gprof的基本用法:
1. 使用 -pg 選項編譯和連結你的應用程式
   
    在gcc編譯器的時候,加上-pg選項,例如:
    gcc -pg -o test test.c
    這樣就產生了可執行檔test。如果是大項目,就在makefile裡面修改編譯選項,-pg放在那裡都行。

2. 執行你的應用程式使之產生供gprof 分析的資料

    運行剛才的程式:./test,這樣就產生了一個gmon.out檔案,該檔案就包含了profiling的資料。

3. 使用gprof 分析你的應用程式產生的資料

    gprof test gmon.out > profile.txt
    使用上面的命令,gprof就可以剖析器test的效能,將profiling的結果放在profile.txt檔案中,開啟就可以看到分析的結果。通過對結果的分析來改進我們的程式,從而達到我們的目的。

GNU gprof是個很不錯的工具,大家寫程式時可以多用用。我現在用gprof來profiling我的程式,把耗時最多的函數或運算找出來,用FPGA晶片實現,從而達到real-time的目的。

 

http://hi.baidu.com/jedora/blog/item/e1b7cffc59f7eb86b801a012.html

http://hujw0710.blog.163.com/blog/static/8797282200952324755785/

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.