成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Ruby on Rails調(diào)試經(jīng)驗分享

開發(fā) 開發(fā)工具
Ruby on Railsc在實際使用中有許多技巧和隱藏的功能值得我們?nèi)ド钊胙芯俊T谶@里我們將會學(xué)到Ruby on Rails調(diào)試的相關(guān)技巧。

Ruby on Rails作為一款非常實用的WEB開發(fā)框架幫助我們實現(xiàn)了快速方便的編寫代碼的需求。下面就為大家介紹一下關(guān)于Ruby on Rails調(diào)試的一些經(jīng)驗之談。#t#

首先,而且也是最重要的就是,編寫測試代碼,在Rails里編寫單元測試和功能測試都很簡單,使用它們,可以減低bug發(fā)生率,也可以避免在你從前的代碼中突然出現(xiàn)bug。

測試代碼告訴你哪些東西能夠工作,哪些不能,并且,測試代碼幫助你隔離那些有問題的代碼,因為有時候bug并非很快地表現(xiàn)出來。

如果Ruby on Rails調(diào)試問題發(fā)生在一個Model中,我們可以使用腳本script/console來模擬一個irb對話,在其中進行跟蹤,例如下面這樣:

  1. Z:studyrubyInstantRailsrails_appsdepot>
    ruby script/console  
  2. Loading development environment.  
  3. >> pr = Product.find(:first)  
  4. => #<Product:0x4b969ec @attributes=
    {"image_url"=
    >"http://www.dearbook.com.  
  5. >> pr.price 
  6. => #<BigDecimal:4b913d4,'0.12351E3',8(12)> 
  7. >> pr.image_url 
  8. => "http://www.dearbook.com.cn/book/
    BookImage/67/lastTS00168921__.jpg"  
  9. >> pr.save 
  10. => true  
  11. >> 

我們先在depot項目的命令行中使用ruby script/console來啟動irb會話,藍色的部分是我在irb會話中輸入的命令。

另外,在復(fù)雜的程序中使用Log也是一個好辦法,你可以在log文件中找到大量有價值的信息,當(dāng)一些意外情況發(fā)生,Log文件應(yīng)該是你第一個要檢查的地方。還有,檢查服務(wù)器的log文件也是很有用的,如果你使用WEBrick作為web服務(wù)器,也可以使用腳本script/server來啟動一個會話。

我們可以使用Logger對象來輸出我們想查看的信息,有時候log文件非常繁忙,以至于很難找到你所添加的log,如果你使用WEBrick,你可以使用STDERR來將你的log輸出到控制臺上(InstantRails使用的Mongrel不能進入命令行)。

如果一個頁面顯示了錯誤的內(nèi)容,我們也許想導(dǎo)出控制器中的對象,方法debug()能幫助我們,該Ruby on Rails調(diào)試方法很好的格式化對象的內(nèi)容,并且判斷對象的內(nèi)容是不是合法的HTML,例如:

 

  1. <h3>Your Order</h3> 
  2. <%= debug(@order) %> 
  3. <div id="ordersummary"> 
  4. . . .  
  5. </div> 

最后,在上面的Ruby on Rails調(diào)試方法都不能排除bug的時候,我們來嘗試跟蹤調(diào)試程序,但是只限于環(huán)境配置為development的程序,下面是使用斷點(breakpoint)的步驟:

1.  在你需要程序停下來的地方添加breakpoint()方法的調(diào)用。

2.  在項目的根目錄鍵入命令:depot>ruby script/breakpointer。

打開瀏覽器,使你的程序能夠命中調(diào)用breakpoint方法的代碼,這時候瀏覽器會停止響應(yīng),在命令行窗口會打開irb會話,在這里,你可以查看變量的值,或者添加斷點,當(dāng)你推出irb會話,在瀏覽器里,程序就會繼續(xù)運行。

責(zé)任編輯:曹凱 來源: 新客網(wǎng)
相關(guān)推薦

2009-12-16 15:23:33

Ruby on rai

2009-12-18 17:01:37

Ruby基礎(chǔ)代碼

2009-12-16 15:46:41

Ruby on rai

2009-12-15 14:51:50

Ruby繼承

2009-12-17 09:49:18

Ruby代碼管理

2009-12-18 17:24:12

Ruby配置Mysql

2009-08-27 10:21:22

Ruby on Rai

2013-05-03 13:45:42

KVM故障調(diào)試

2009-08-06 09:13:36

Ruby on Rai

2012-01-30 13:58:36

Linux Deepi Gnome Shel

2009-12-14 15:30:43

安裝Ruby on R

2015-10-14 17:27:18

性能

2009-12-17 14:29:50

Ruby on Rai

2015-10-10 11:00:05

RubyRails性能

2009-12-16 15:41:10

Ruby on Rai

2009-12-16 17:37:31

Ruby on Rai

2009-12-17 17:37:42

Ruby on Rai

2010-09-25 14:39:29

Bruce Tate

2013-03-28 12:42:02

RubyRails

2009-09-29 17:04:29

點贊
收藏

51CTO技術(shù)棧公眾號

主站蜘蛛池模板: 男人天堂手机在线视频 | 午夜影院在线观看版 | 日韩久久久久久 | 国产伦精品一区二区三区在线 | 国产综合久久 | 91视频一区二区三区 | 国产极品车模吞精高潮呻吟 | 久久精品国产久精国产 | 中文字幕亚洲欧美日韩在线不卡 | 久久小视频 | 亚洲欧美成人影院 | 成人在线欧美 | 久久精品久久久久久 | 龙珠z国语版在线观看 | 国产乱码久久久久久 | 国产精品视频一区二区三 | 99久久精品一区二区毛片吞精 | 亚洲黄色成人网 | 色视频成人在线观看免 | 欧美v在线观看 | 国产精品国产三级国产aⅴ中文 | 中国一级特黄毛片大片 | 久久精品视频9 | 人人做人人澡人人爽欧美 | 久久久久久国产精品 | 人人爽人人草 | 久久免费高清视频 | 久热中文字幕 | 欧美专区日韩 | 欧美韩一区二区 | 国产一区二区精品在线 | 亚洲国产激情 | 97国产爽爽爽久久久 | 久久伊人精品 | 国产美女精品 | 在线成人精品视频 | 国产精品久久久久久久久久三级 | 日韩精品一区二区三区中文字幕 | 99久久久99久久国产片鸭王 | 亚洲一区二区三区视频 | 涩爱av一区二区三区 |