日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問(wèn)題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營(yíng)銷解決方案
Ruby實(shí)現(xiàn)stream具體方法介紹

Ruby語(yǔ)言在編程界可以說(shuō)是一個(gè)后起之秀,出現(xiàn)的目的就是幫助編程人員更簡(jiǎn)便靈活的去編寫代碼程序,完成自己的功能需求。比如在Ruby實(shí)現(xiàn)stream方面。#t#

按照sicp,首要的是兩個(gè)函數(shù):delay和force:

  1. def mem_proc(exp)  
  2. alread_run=false 
  3. result=false 
  4. lambda{  
  5. if !alread_run  
  6. result=exp.call  
  7. alread_run=true 
  8. result  
  9. else  
  10. result  
  11. end  
  12. }  
  13. end  
  14. def force(delayed_object)  
  15. delayed_object.call  
  16. end  
  17. def delay(exp)  
  18. mem_proc(lambda{exp})  
  19. end 

delay函數(shù)返回延時(shí)對(duì)象,就是對(duì)于未來(lái)某個(gè)時(shí)間求值表達(dá)式的承諾;force函數(shù)以延時(shí)對(duì)象為參數(shù),進(jìn)行相應(yīng)的求值工作,這里的mem_proc用于記憶已經(jīng)求值過(guò)的表達(dá)式。Ruby實(shí)現(xiàn)stream的constructor和selector函數(shù):

 
 
 
  1. def cons_stream(a,b)  
  2. return a,delay(b)  
  3. end  
  4. def stream_car(s)  
  5. s[0]  
  6. end  
  7. def stream_cdr(s)  
  8. force(s[1])  
  9. end  
  10. def stream_null?(s)  
  11. s.nil? or s==[]  
  12. end  

用Ruby中的數(shù)組充當(dāng)“粘合劑”,stream_car直接返回***個(gè)元素,而stream_cdr需要用force求值表達(dá)式,履行承諾。另外,將空數(shù)組[]作為the-empty-stream。再定義幾個(gè)高階函數(shù),map和foreach,其他如filter與此類似:

 
 
 
  1. def stream_enumerate_interval(low,high)  
  2.  if low>high  
  3.   return []  
  4.  else  
  5.   cons_stream(low,stream_enumerate
    _interval(low.succ,high))    
  6.  end  
  7. end  
  8. def stream_ref(s,n)  
  9.  if n==0  
  10.   stream_car(s)  
  11.  else  
  12.   stream_ref(stream_cdr(s),(n-1))    
  13. end  
  14. end  
  15. def stream_map(proc,s)  
  16. if stream_null?(s)  
  17. []  
  18. else  
  19. cons_stream(proc.call(stream_car(s))
    ,stream_map(proc,(stream_cdr(s))))    
  20. end  
  21. end  
  22. def stream_for_each(proc,s)  
  23. if stream_null?(s)  
  24. :done  
  25. else  
  26. proc.call(stream_car(s))  
  27. stream_for_each(proc,stream_cdr(s))    
  28. end  
  29. end  
  30. def display_stream(s)  
  31. stream_for_each(lambda{|item| puts item},s)  
  32. end  
  33. def stream_filter(pred,s)  
  34. if stream_null?(s)  
  35. []  
  36. elsif pred.call(stream_car(s))  
  37. cons_stream(stream_car(s),stream_
    filter(pred,stream_cdr(s)))  
  38. else  
  39. stream_filter(pred,stream_cdr(s))   
  40. end  
  41. end 

***,看下Ruby實(shí)現(xiàn)stream例子:

 
 
 
  1. puts "s:"  
  2. s=stream_enumerate_interval(1,5)  
  3. display_stream(s)  
  4. puts "odd_s:"  
  5. odd_s=stream_filter
    (lambda{|x| x%2==1},s)  
  6. display_stream(odd_s)  
  7. puts "ss:"  
  8. ss=stream_map(lambda{|x|x*x},s)  
  9. display_stream(ss)  

當(dāng)前名稱:Ruby實(shí)現(xiàn)stream具體方法介紹
標(biāo)題網(wǎng)址:http://www.5511xx.com/article/cosgded.html