校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > 優化Ruby代碼使程序運行速度提高的例子

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

熱門標簽:中牟外呼系統違法嗎 AI電銷機器人 線路 外呼線路從哪里出來的 漯河電銷 天津外呼系統怎么收費 柯城手機地圖如何做地圖標注 征服者企業地圖標注 巫師3地圖標注魔力之所 淮安自動外呼系統供應商

這篇文章主要介紹了我是如何把ruby gem contracts.ruby速度提升10倍的。

contracts.ruby在我項目里用來添加代碼合約(code contracts)到Ruby中。看起來差不多是這樣的:

Contract Num, Num => Num
def add(a, b)
 a + b
end

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

20秒

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

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

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

8秒

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

def self.success_callback(data)
end 

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

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

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

5.93秒

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

if contract.is_a?(Class)
 # check arg
elsif 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秒時間。

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

5.09秒

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

結果證明:

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秒:

2.94秒

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

1.57秒

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

# simplification
old_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}", name
class_eval %{%{
  def #{name}(*args)def #{name}(*args)
    self.send(:"original_#{name}", *args)self.send(:"original_#{name}", *args)
   endend
}}

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

結果

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

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

稍微慢了點!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
 endend
endend

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

2.關鍵字old

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

class Foo Foo
 def bardef bar
  'Hello''Hello'
 endend
end end 

class Fooclass Foo
 def bardef bar
  old + ' World'+ ' World'
 endend
endend

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中的異常
  • 在Ruby中處理文件的輸入和輸出的教程
  • Ruby中操作文件的方法介紹

標簽:南昌 甘孜 大慶 西雙版納 河池 棗莊 克拉瑪依 內江

巨人網絡通訊聲明:本文標題《優化Ruby代碼使程序運行速度提高的例子》,本文關鍵詞  優化,Ruby,代碼,使,程序,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《優化Ruby代碼使程序運行速度提高的例子》相關的同類信息!
  • 本頁收集關于優化Ruby代碼使程序運行速度提高的例子的相關信息資訊供網民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    日韩欧美一区二区久久婷婷| 欧美一二三在线| 欧美日韩免费观看一区二区三区 | 青青草97国产精品免费观看无弹窗版| 色综合天天性综合| 性久久久久久久| 欧美成人a∨高清免费观看| 激情综合网av| 1区2区3区欧美| 欧美在线|欧美| 捆绑调教一区二区三区| 欧美国产激情二区三区 | 制服.丝袜.亚洲.中文.综合| 日本欧美肥老太交大片| 久久久久久久综合日本| 色综合色综合色综合色综合色综合| 亚洲综合色在线| 精品国产免费人成电影在线观看四季 | 久久天堂av综合合色蜜桃网| 成人一区二区三区在线观看| 一区二区三区丝袜| 欧美日韩精品一区二区在线播放| 亚洲综合久久av| 久久久久久夜精品精品免费| 欧美视频在线观看一区二区| 国产精品一品二品| 日韩电影在线一区二区| 亚洲欧美一区二区视频| 日韩免费在线观看| 欧美视频三区在线播放| 成人美女在线视频| 国产麻豆一精品一av一免费| 亚洲成a人v欧美综合天堂下载| 久久综合久久综合久久| 欧美伦理视频网站| 97se亚洲国产综合自在线观| 激情伊人五月天久久综合| 亚洲国产毛片aaaaa无费看| 国产精品网站在线观看| 日韩三级视频在线观看| 欧美视频一区二区三区| 一本大道久久a久久综合| 成人爽a毛片一区二区免费| 久久国产精品99久久人人澡| 日韩成人一级大片| 香蕉成人伊视频在线观看| 亚洲丝袜另类动漫二区| 中文无字幕一区二区三区| 精品精品国产高清a毛片牛牛| 欧美男人的天堂一二区| 欧美性猛片aaaaaaa做受| 97久久精品人人做人人爽| 成人美女视频在线观看18| 国产成人无遮挡在线视频| 国产一区二区三区高清播放| 韩日av一区二区| 狠狠色丁香久久婷婷综| 国产一区二区主播在线| 九九精品一区二区| 国产很黄免费观看久久| 国产成人高清在线| 豆国产96在线|亚洲| 成人免费视频视频| 91福利在线免费观看| 欧美系列亚洲系列| 欧美肥妇毛茸茸| 日韩欧美一区二区久久婷婷| 久久亚洲一级片| 国产亚洲精品aa午夜观看| 国产精品美女一区二区三区| 亚洲色图都市小说| 视频一区在线视频| 国产一区二区主播在线| 99国产一区二区三精品乱码| 色999日韩国产欧美一区二区| 欧美在线观看一区| 精品乱码亚洲一区二区不卡| 国产欧美日韩亚州综合 | 洋洋成人永久网站入口| 亚洲福利国产精品| 老司机精品视频线观看86 | 欧洲av一区二区嗯嗯嗯啊| 欧美亚洲一区三区| 日韩欧美国产一区二区在线播放| 久久久不卡影院| 国产精品国产三级国产普通话99| 亚洲精品视频免费观看| 喷水一区二区三区| 99riav一区二区三区| 91精品国产麻豆国产自产在线| 久久精品欧美一区二区三区不卡| 亚洲三级小视频| 老鸭窝一区二区久久精品| 91网址在线看| 26uuu国产电影一区二区| 一区二区三区在线免费观看| 青青国产91久久久久久| 91香蕉国产在线观看软件| 精品国产乱码久久久久久蜜臀 | 日本一区二区三区四区| 亚洲免费观看高清完整| 激情综合网最新| 欧美日韩免费视频| 最新高清无码专区| 国产尤物一区二区| 91精品欧美综合在线观看最新| 国产精品网站在线观看| 另类小说欧美激情| 欧美精品丝袜中出| 亚洲美女屁股眼交3| 国产精品综合av一区二区国产馆| 欧美日韩午夜在线视频| 中文字幕人成不卡一区| 国产剧情一区二区三区| 欧美一级xxx| 五月激情丁香一区二区三区| 97精品国产露脸对白| 久久九九影视网| 久久国产乱子精品免费女| 91精品国产综合久久久久久漫画| 综合久久一区二区三区| 成人精品视频网站| 国产亚洲综合性久久久影院| 美女一区二区三区| 制服丝袜一区二区三区| 日韩av网站免费在线| 在线播放亚洲一区| 日本亚洲免费观看| 日韩三级av在线播放| 蜜桃视频在线观看一区二区| 欧美一卡二卡三卡四卡| 日韩精品一区第一页| 欧美日韩免费视频| 日本欧洲一区二区| 日韩欧美在线网站| 国内精品国产三级国产a久久| 欧美成人福利视频| 国产一区日韩二区欧美三区| 久久久久久久久久久久久女国产乱 | 日日夜夜免费精品视频| 日韩欧美黄色影院| 国产一区激情在线| 中文字幕av不卡| av激情综合网| 亚洲人成网站精品片在线观看| 一本色道久久综合亚洲精品按摩| 亚洲精品五月天| 欧美日韩一区二区不卡| 美女视频黄久久| 国产亚洲成年网址在线观看| 成人av在线电影| 亚洲一卡二卡三卡四卡| 91精品国产免费| 国产99精品视频| 亚洲精品日日夜夜| 日韩美女主播在线视频一区二区三区| 国产真实乱对白精彩久久| 国产精品国产自产拍高清av| 欧美日韩亚洲综合在线| 韩国v欧美v亚洲v日本v| 成人免费在线播放视频| 欧美日韩国产高清一区二区 | 欧美日韩大陆一区二区| 捆绑变态av一区二区三区| 中文字幕巨乱亚洲| 欧美午夜片在线观看| 黄一区二区三区| 亚洲人成网站色在线观看| 欧美一区二区三区系列电影| 国产69精品久久777的优势| 亚洲国产欧美在线| 久久精品视频一区二区| 欧美三级电影在线看| 国产精品一区久久久久| 亚洲欧美激情视频在线观看一区二区三区 | 国产丝袜美腿一区二区三区| 国内成人精品2018免费看| 国产精品久久影院| 91精品国产综合久久精品麻豆 | 91国偷自产一区二区三区成为亚洲经典| 日日骚欧美日韩| 成人免费小视频| 精品国产一区二区国模嫣然| 色av成人天堂桃色av| 欧美日韩一区二区三区高清| 在线观看国产日韩| 久久这里只有精品首页| 欧美日韩黄色一区二区| 国产成人久久精品77777最新版本| 亚洲婷婷国产精品电影人久久| 亚洲电影视频在线| 亚洲va韩国va欧美va精品 | 人人超碰91尤物精品国产| 欧美精品乱码久久久久久按摩| 日产国产欧美视频一区精品| 亚洲色大成网站www久久九九| 寂寞少妇一区二区三区| 激情综合网激情| 一级日本不卡的影视| 国产精品丝袜久久久久久app|