亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > Ruby > 正文

優化Ruby代碼使程序運行速度提高的例子

2020-02-24 15:38:31
字體:
來源:轉載
供稿:網友

本文介紹了如何優化Ruby代碼以提高程序的運行速度,本文中引用的項目將Ruby項目的運行時間從20秒優化為1.5秒,需要它的朋友可以參考武林技術頻道小編為大家介紹的內容,一起來看看吧!

contracts.ruby在我項目里用來添加代碼合約(code contracts)到Ruby中??雌饋聿畈欢嗍沁@樣的:

Contract Num, Num => Numdef add(a, b) a + bend

只要add方法被調用,參數和返回值都會被檢查。

20秒

本周末,我對該庫進行了測試,發現其性能非常糟:

2015410153558748.jpg (631×116)

這是在隨機輸入下,運行1000次以后的結果。

所以,當給一個函數加入合約功能后,運行速度明顯下降(約40倍這樣),對此,我進行了深入的研究。

8秒

我取得了較大的進展,當傳遞合約時,我調用success_callback函數,該函數是個空函數,下面是這個函數的整個定義:

def self.success_callback(data)end 

原來函數調用在Ruby中是非常昂貴的,僅刪除這個調用,就節省了8秒鐘:

2015410153638929.jpg (635×108)刪除其它一些附件函數的調用,時間花費開始從9.84-> 9.59-> 8.01秒,該庫的速度馬上提升到以前的兩倍了。

現在,事情變的有點復雜了。

5.93秒

這里有許多年種定義一個合約的方式:匿名(lambdas)、類 (classes)、簡單舊數據(plain ol' values)等。 我有個很長的case語句,用來檢測合約的類型。在此合約類型基礎之上,我可以做不同的事情。通過把它改為if語句,我節約了一些時間,但每次調用這個函數時,我仍然耗費了不必要的時間在仔細檢查這個判定樹上面:

if contract.is_a?(Class) # check argelsif contract.is_a?(Hash) # check arg...

當定義合約和構建lambda時,對樹只做一次檢查:

if contract.is_a?(Class) lambda { |arg| # check arg }elsif contract.is_a?(Hash) lambda { |arg| # check arg }

然后,我將完全繞過邏輯分支,通過將參數傳遞給預計算的lambda來進行驗證,這樣就節約了1.2秒時間。

2015410153721524.jpg (654×126)

預計算一些其它的If語句,差不多又節省了1秒時間:

2015410153747882.jpg (635×111)

5.09秒

將.zip轉換為.times又為我節省了1秒時間:

2015410153823207.jpg (647×112)

結果證明:

args.zip(contracts).each do |arg, contract|

上面的代碼要比下面這個慢:

args.each_with_index do |arg, i|

要比下面這個更慢:

args.size.times do |i|

.zip要花費不必要的時間復制和創建新的數組。而我認為,.each_with_index之所以慢,是因為它受制于背后的.each,所以它涉及到兩個限制而不是一個。

4.23秒

下面再看些細節的東西,contracts庫在工作時,它會為每一個方法添加class_eval(class_eval要比define_method快)的新方法,這個新方法里有一個對老方法的引用,當調用新方法時,它會檢查參數,然后根據參數調用老方法,然后再檢查返回值,并且返回值。所有這些都會調用Contract class的check_args和check_result兩個方法。我取消了這兩個方法的調用,并且對新方法進行正確檢查,結果又節省了0.9秒:

2015410153859686.jpg (645×144)

2.94秒

在上面,我已經解釋了如何基于Contract類型創建lambda,然后使用這些來檢驗參數?,F在,我換了種方法,用生成代碼來替代,當我使用class_eval創建新方法時,它就會從eval中獲得結果。一個可怕的漏洞,但它避免了一大堆方法調用,并且節省了1.25秒:

2015410153935485.jpg (644×112)

1.57秒

最后,我改變了調用重寫方法的方式,我先前是使用引用:

# simplificationold_method = method(name)= method(name)class_eval %{%{  def #{name}(*args)def #{name}(*args)    old_method.bind(self).call(*args).bind(self).call(*args)  endend}}

我進行了修改,并使用alias_method方法:

alias_method :"original_#{name}", name:"original_#{name}", nameclass_eval %{%{  def #{name}(*args)def #{name}(*args)    self.send(:"original_#{name}", *args)self.send(:"original_#{name}", *args)   endend}}

驚喜,又節省了1.4秒。我不知道為什么aliaa_method會如此地快,我猜是因為它跳過了一個方法的調用和綁定到.bindbind。

2015410154007723.jpg (645×115)

結果

我們成功的將時間從20秒優化到1.5秒,我不認為還有比這更好的結果的了。我所編寫的 這個測試腳本表明,一個被封裝過的add方法要比常規的add方法慢3倍,所以這些數字已經足夠好了。

想要驗證上面的結論很簡單,大量的時間花在調用方法上是只慢3倍的原因,這里有個更現實的例子:一個函數讀一個文件100000次:

2015410154044692.jpg (640×118)

稍微慢了點!add函數是個例外,我決定不再使用alias_method方法,因為它污染了命名空間,并且這些別名函數會到處出現(文檔、IDE的自動完成等)。

其它原因:

??? 在Ruby中調用方法很慢,我喜歡將代碼模塊化和重復使用,但或許是時候將更多的代碼進行內聯了。
??? 測試你的代碼!刪掉一個簡單的未使用的方法時間從20秒縮短到了12秒。

其它嘗試

1.方法選擇器

Ruby 2.0里缺少方法選擇器這一特性,否則你還可以這樣寫:

class Foo Foo def bar:beforedef bar:before  # will always run before bar, when bar is called# will always run before bar, when bar is called endend def bar:afterdef bar:after  # will always run after bar, when bar is called# will always run after bar, when bar is called  # may or may not be able to access and/or change bar's return value# may or may not be able to access and/or change bar's return value endendendend

這樣可能會更加容易編寫decorator,并且運行速度也會加快。

2.關鍵字old

Ruby 2.0里缺乏的另一特性是引用重寫方法:

class Foo Foo def bardef bar  'Hello''Hello' endendend end class Fooclass Foo def bardef bar  old + ' World'+ ' World' endendendend

Foo.new.bar # => 'Hello World'Foo.new.bar # => 'Hello World'

3.使用redef重新定義方法:

Matz曾說過:

??? 為了消除alias_method_chain,我們引入了Module#prepend,prepend前面加#號,這樣就沒機會在語言里加入冗余特性。

所以如果redef是冗余特征,也許prepend可以用來寫decorator?

4.其它實現

目前為止,這些都已經在YARV做過測試。

以上這些是武林技術頻道小編給大家介紹的優化Ruby代碼使程序運行速度提高的例子,閱讀了這篇文章,大家是否有所了解了呢?

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
91欧美日韩一区| 91久久精品国产91久久| 久久精品国产亚洲一区二区| 国产成人亚洲综合91| 孩xxxx性bbbb欧美| 91精品国产综合久久久久久久久| 亚洲欧洲激情在线| 亚洲资源在线看| 中文字幕日韩免费视频| 91最新国产视频| 日韩在线一区二区三区免费视频| 国产精品一久久香蕉国产线看观看| 欧美日韩国产成人高清视频| 亚洲国产精品中文| 26uuu亚洲伊人春色| 夜色77av精品影院| 久久久91精品国产一区不卡| 精品国产91久久久久久| 亚洲欧洲国产一区| 日韩av在线免费播放| 中文字幕亚洲二区| 亚洲男人av电影| 欧美大片在线影院| 日韩在线高清视频| 57pao成人永久免费视频| 91精品久久久久久综合乱菊| 亚洲精品国产精品国产自| 亚洲成avwww人| 国产日韩在线看片| 亚洲精品国偷自产在线99热| 激情成人中文字幕| 日韩欧美精品在线观看| 国产综合香蕉五月婷在线| 国产成人一区二区三区小说| 26uuu另类亚洲欧美日本老年| 成人性生交大片免费看小说| 久久av.com| 欧美日韩亚洲激情| 在线看日韩av| 国产精品自拍偷拍视频| 一区二区三区四区精品| 国产精品狼人色视频一区| 最近2019中文字幕第三页视频| 国产日韩精品一区二区| 欧美美女18p| 亚洲欧美中文字幕| 亚洲第一中文字幕| 久久久久久久久久亚洲| 78色国产精品| 亚洲国产欧美一区二区丝袜黑人| 午夜精品福利在线观看| 国产精品久久电影观看| 日韩国产精品一区| 欧美xxxx18性欧美| 久久久久久亚洲精品| www.日韩视频| 国产日韩欧美视频| 日韩中文字幕视频在线| 26uuu亚洲伊人春色| 精品视频偷偷看在线观看| 一区二区三区回区在观看免费视频| 国产精品福利在线| 亚洲国产精品99久久| 国产在线精品成人一区二区三区| 欧美一区二三区| 亚洲精品一区二区三区婷婷月| 成人国产精品久久久久久亚洲| 欧美乱大交xxxxx另类电影| 在线观看久久av| 国产精品三级久久久久久电影| 国产精品久久久久久久av电影| 日韩大陆欧美高清视频区| 91在线|亚洲| 国产精品白嫩美女在线观看| 91九色视频导航| 精品久久久国产| 91免费看国产| 日本视频久久久| 亚洲黄页视频免费观看| 欧美疯狂做受xxxx高潮| 国产精品偷伦免费视频观看的| 欧美日韩中文在线观看| 欧美俄罗斯性视频| 国产视频久久网| 欧美在线视频观看免费网站| 97在线视频观看| 亚洲自拍高清视频网站| 精品自在线视频| 91社影院在线观看| 亚洲电影免费观看高清| 国内精品小视频在线观看| 亚洲国产成人av在线| 精品自拍视频在线观看| 亚洲自拍偷拍在线| 国产精品精品一区二区三区午夜版| 日韩中文字幕在线| 有码中文亚洲精品| 91精品国产一区| 日韩视频欧美视频| 动漫精品一区二区| 中日韩美女免费视频网址在线观看| 欧美片一区二区三区| 亚洲乱码国产乱码精品精天堂| 大荫蒂欧美视频另类xxxx| 国产91精品青草社区| 日本久久久久亚洲中字幕| 国产精品美女视频网站| 国产精品久久久久一区二区| 欧美刺激性大交免费视频| 欧美激情视频三区| 亚洲精品国产美女| 中文字幕免费精品一区高清| 91精品视频播放| 一区二区三区四区视频| 亚洲天堂开心观看| 国产精品在线看| 亚洲国产精品悠悠久久琪琪| 最近2019中文字幕一页二页| 亚洲激情中文字幕| 国产亚洲精品久久久优势| 奇米影视亚洲狠狠色| 精品丝袜一区二区三区| 国产成人亚洲综合| 秋霞午夜一区二区| 国产精品入口免费视| 日韩免费电影在线观看| 国产精品露脸av在线| 成人性生交大片免费看小说| 日韩欧美aⅴ综合网站发布| 琪琪亚洲精品午夜在线| 午夜精品蜜臀一区二区三区免费| 国产一区二区免费| 国产精品视频一区二区高潮| 亚洲午夜激情免费视频| 日韩hd视频在线观看| 日韩精品高清视频| 久久视频在线观看免费| 亚洲精品国产综合区久久久久久久| 亚洲第一视频网| 91国内免费在线视频| 91大神福利视频在线| 国产aⅴ夜夜欢一区二区三区| 日韩中文字幕在线免费观看| 亚洲欧美成人精品| 亚洲色图18p| 午夜剧场成人观在线视频免费观看| 亚洲精品wwww| 欧美重口另类videos人妖| 91麻豆国产语对白在线观看| 国产午夜精品免费一区二区三区| 亚洲精品视频中文字幕| 久久成人这里只有精品| 亚洲成av人影院在线观看| 欧美激情欧美激情在线五月| 国产精品mp4| 亚洲视频网站在线观看| 91精品国产91久久久久久吃药| 在线电影欧美日韩一区二区私密| 日韩欧美福利视频| 色青青草原桃花久久综合| 亚洲黄色www| 日韩成人xxxx| 欧美激情性做爰免费视频| 亚洲人成网7777777国产|