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

首頁 > 編程 > Ruby > 正文

淺析Ruby的源代碼布局及其編程風格

2020-10-29 19:37:44
字體:
來源:轉載
供稿:網友

使用 UTF-8 作為源文件編碼。

    每個縮進級別使用兩個 spaces (又名軟 tabs). 不要硬 tabs

  # bad - four spaces  def some_method    do_something  end  # good  def some_method   do_something  end

    使用 Unix-風格 換行符。(*BSD/Solaris/Linux/OSX 用戶被為默認涵蓋,Windows 用戶必須特別小心.)

  •         /n是換行,英文是LineFeed,ASCII碼是0xA。
  •         /r是回車,英文是Carriage Return ,ASCII碼是0xD。
  •         windows下enter是 /n/r,unix下是/n,mac下是/r

        如果你正在使用 Git 你可能會想要添加下面的配置設置來保護你的項目(避免)Windows 蔓延過來的換行符:

 

  $ git config --global core.autocrlf true

    不用使用 ; 來分割語句和表達式。以此推論 - 一行使用一個表達式

  

 # bad  puts 'foobar'; # superfluous semicolon  puts 'foo'; puts 'bar' # two expression on the same line  # good  puts 'foobar'  puts 'foo'  puts 'bar'  puts 'foo', 'bar' # this applies to puts in particular

    對于沒有內容的類定義,盡可能使用單行類定義形式.

   

 # bad  class FooError < StandardError  end  # okish  class FooError < StandardError; end  # good  FooError = Class.new(StandardError)

    避免單行方法。即便還是會受到一些人的歡迎,這里還是會有一些古怪的語法用起來很容易犯錯.
    無論如何 - 應該一行不超過一個單行方法.

    

# bad  def too_much; something; something_else; end  # okish - notice that the first ; is required  def no_braces_method; body end  # okish - notice that the second ; is optional  def no_braces_method; body; end  # okish - valid syntax, but no ; make it kind of hard to read  def some_method() body end  # good  def some_method   body  end

    空方法是這個規則的例外。

  # good  def no_op; end

    操作符旁的空格,在逗號,冒號和分號后;在 { 旁和在 } 之前,大多數空格可能對 Ruby 解釋(代碼)無關,但是它的恰當使用是讓代碼變得易讀的關鍵。

  sum = 1 + 2  a, b = 1, 2  1 > 2 ? true : false; puts 'Hi'  [1, 2, 3].each { |e| puts e }

    唯一的例外是當使用指數操作時:

  # bad  e = M * c ** 2  # good  e = M * c**2

    { 和 } 值得額外的澄清,自從它們被用于 塊 和 hash 字面量,以及以表達式的形式嵌入字符串。
    對于 hash 字面量兩種風格是可以接受的。

  # good - space after { and before }  { one: 1, two: 2 }  # good - no space after { and before }  {one: 1, two: 2}

    第一種稍微更具可讀性(并且爭議的是一般在 Ruby 社區里面更受歡迎)。
    第二種可以增加了 塊 和 hash 可視化的差異。
    無論你選哪一種都行 - 但是最好保持一致。

    目前對于嵌入表達式,也有兩個選擇:

  # good - no spaces  "string#{expr}"  # ok - arguably more readable  "string#{ expr }"

    第一種風格極為流行并且通常建議你與之靠攏。第二種,在另一方面,(有爭議)更具可讀性。
    如同 hash - 選取一個風格并且保持一致。

    沒有空格 (, [之后或者 ], )之前。

 

  some(arg).other  [1, 2, 3].length  ! 之后沒有空格 .  # bad  ! something  # good  !something

    when和case 縮進深度一致。我知道很多人會不同意這點,但是它是"The Ruby Programming Language" 和 "Programming Ruby"中公認的風格。

    

# bad  case   when song.name == 'Misty'    puts 'Not again!'   when song.duration > 120    puts 'Too long!'   when Time.now.hour > 21    puts "It's too late"   else    song.play  end  # good  case  when song.name == 'Misty'   puts 'Not again!'  when song.duration > 120   puts 'Too long!'  when Time.now.hour > 21   puts "It's too late"  else   song.play  end  case  when song.name == 'Misty'   puts 'Not again!'  when song.duraton > 120   puts 'Too long!'  when Time.now > 21   puts "It's too late"  else   song.play  end

    當賦值一個條件表達式的結果給一個變量時,保持分支的縮排在同一層。

 

  # bad - pretty convoluted  kind = case year  when 1850..1889 then 'Blues'  when 1890..1909 then 'Ragtime'  when 1910..1929 then 'New Orleans Jazz'  when 1930..1939 then 'Swing'  when 1940..1950 then 'Bebop'  else 'Jazz'  end  result = if some_cond   calc_something  else   calc_something_else  end  # good - it's apparent what's going on  kind = case year      when 1850..1889 then 'Blues'      when 1890..1909 then 'Ragtime'      when 1910..1929 then 'New Orleans Jazz'      when 1930..1939 then 'Swing'      when 1940..1950 then 'Bebop'      else 'Jazz'      end  result = if some_cond        calc_something       else        calc_something_else       end  # good (and a bit more width efficient)  kind =   case year   when 1850..1889 then 'Blues'   when 1890..1909 then 'Ragtime'   when 1910..1929 then 'New Orleans Jazz'   when 1930..1939 then 'Swing'   when 1940..1950 then 'Bebop'   else 'Jazz'   end  result =   if some_cond    calc_something   else    calc_something_else   end

    在方法定義之間使用空行并且一個方法根據邏輯段來隔開。

   

 def some_method   data = initialize(options)   data.manipulate!   data.result  end  def some_methods   result  end

    避免在一個方法調用的最后一個參數有逗號,特別是當參數不在另外一行。

   

 # bad - easier to move/add/remove parameters, but still not preferred  some_method(         size,         count,         color,        )  # bad  some_method(size, count, color, )  # good  some_method(size, count, color)

    當給方法的參數賦默認值時,在 = 兩邊使用空格:

  

 # bad  def some_method(arg1=:default, arg2=nil, arg3=[])   # do something...  end  # good  def some_method(arg1 = :default, arg2 = nil, arg3 = [])   # do something...  end

    雖然幾本 Ruby 書建議用第一個風格,不過第二個風格在實踐中更為常見(并可爭議地可讀性更高一點)。

    避免在不需要的時候使用行繼續符 / 。實踐中,
    除非用于連接字符串, 否則避免在任何情況下使用行繼續符。

 

  # bad  result = 1 - /       2  # good (but still ugly as hell)  result = 1 /       - 2  long_string = 'First part of the long string' /         ' and second part of the long string'

    采用連貫的多行方法鏈式風格。在 Ruby 社區有兩種受歡迎的風格,它們都被認為很好
    - . 開頭(選項 A) 和 尾隨 . (選項 B) 。

        (選項 A) 當一個鏈式方法調用需要在另一行繼續時,將 . 放在第二行。

        

# bad - need to consult first line to understand second line    one.two.three.     four    # good - it's immediately clear what's going on the second line    one.two.three     .four

        (選項 B) 當在另一行繼續一個鏈式方法調用,將 . 放在第一行來識別要繼續的表達式。

     

  # bad - need to read ahead to the second line to know that the chain continues    one.two.three     .four    # good - it's immediately clear that the expression continues beyond the first line    one.two.three.     four

        在這里可以發現有關這兩個另類風格的優點的討論。

    如果一個方法調用的跨度超過了一行,對齊它們的參數。當參數對齊因為行寬限制而不合適,
    在第一行之后單縮進也是可以接受的。

  

 # starting point (line is too long)  def send_mail(source)   Mailer.deliver(to: 'bob@example.com', from: 'us@example.com', subject: 'Important message', body: source.text)  end  # bad (double indent)  def send_mail(source)   Mailer.deliver(     to: 'bob@example.com',     from: 'us@example.com',     subject: 'Important message',     body: source.text)  end  # good  def send_mail(source)   Mailer.deliver(to: 'bob@example.com',           from: 'us@example.com',           subject: 'Important message',           body: source.text)  end  # good (normal indent)  def send_mail(source)   Mailer.deliver(    to: 'bob@example.com',    from: 'us@example.com',    subject: 'Important message',    body: source.text   )  end

    對齊多行跨度的 array literals 的元素。

   

 # bad - single indent  menu_item = ['Spam', 'Spam', 'Spam', 'Spam', 'Spam', 'Spam', 'Spam', 'Spam',   'Baked beans', 'Spam', 'Spam', 'Spam', 'Spam', 'Spam']  # good  menu_item = [   'Spam', 'Spam', 'Spam', 'Spam', 'Spam', 'Spam', 'Spam', 'Spam',   'Baked beans', 'Spam', 'Spam', 'Spam', 'Spam', 'Spam'  ]  # good  menu_item =   ['Spam', 'Spam', 'Spam', 'Spam', 'Spam', 'Spam', 'Spam', 'Spam',    'Baked beans', 'Spam', 'Spam', 'Spam', 'Spam', 'Spam']

    大數值添加下劃線來提高它們的可讀性。

  # bad - how many 0s are there?  num = 1000000  # good - much easier to parse for the human brain  num = 1_000_000

    使用 RDoc 以及它的慣例來撰寫 API 文檔。注解區塊及 def 不要用空行隔開。

    每一行限制在 80 個字符內。

    避免行尾空格。

    不要使用區塊注釋。它們不能由空白引導(=begin 必須頂頭開始),并且不如普通注釋容易辨認。

 

  # bad  == begin  comment line  another comment line  == end  # good  # comment line  # another comment line

    在 API 文檔中使用 RDoc和它的公約。不要在注釋代碼塊和def之間加入空行。

    保持每一行少于80字符。

    避免尾隨空格。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美黑人又粗大| 色妞久久福利网| 欧美日韩另类视频| 91精品一区二区| 亚洲日本欧美日韩高观看| 欧美大片免费观看在线观看网站推荐| 粉嫩老牛aⅴ一区二区三区| 欧美大片在线影院| 欧美在线一级va免费观看| 亚洲色图在线观看| 色偷偷偷综合中文字幕;dd| 国产精品青青在线观看爽香蕉| 理论片在线不卡免费观看| 欧美成人免费在线观看| 成人有码视频在线播放| 精品女同一区二区三区在线播放| 亚洲精品二三区| 一区二区欧美久久| 久久久久久一区二区三区| 91天堂在线视频| 久久久国产影院| 91国偷自产一区二区三区的观看方式| xvideos亚洲人网站| 欧美激情第一页xxx| 亚洲free性xxxx护士hd| 亚洲日韩欧美视频| 91亚洲永久免费精品| 精品在线小视频| 国产日韩在线亚洲字幕中文| 国产精品亚洲美女av网站| 欧美日韩综合视频| 欧美日韩不卡合集视频| 日韩中文字幕免费视频| 亚洲自拍偷拍福利| 亚洲va久久久噜噜噜久久天堂| 91精品在线一区| 久久精品国产成人精品| 91爱爱小视频k| 青草成人免费视频| 亚洲激情电影中文字幕| 午夜精品久久久久久久男人的天堂| 福利一区福利二区微拍刺激| 成人精品久久久| 国产精品自产拍高潮在线观看| 欧美在线影院在线视频| 欧美理论电影网| 久久精品人人爽| 国产成人精品综合| 久久综合国产精品台湾中文娱乐网| 欧美国产在线电影| 欧美一区二区色| 亚洲日本aⅴ片在线观看香蕉| 日韩精品一区二区视频| 国产精品成人国产乱一区| 久久久久女教师免费一区| 九九热视频这里只有精品| 亚洲日本中文字幕免费在线不卡| 欧美电影院免费观看| 精品欧美aⅴ在线网站| 久久影视电视剧免费网站清宫辞电视| 91在线观看免费高清完整版在线观看| 久久久久亚洲精品成人网小说| 亚洲欧美综合另类中字| 久久中文字幕国产| 国产欧美一区二区白浆黑人| 日韩av手机在线| 国产精品永久在线| 久久男人av资源网站| 欧美大片免费看| www.久久久久| 久久精品影视伊人网| 亚洲a区在线视频| 精品福利免费观看| 欧美老少做受xxxx高潮| 一区二区欧美在线| 久久久久久久久久久人体| 日韩在线观看视频免费| 国产一区二区三区视频在线观看| 欧美性一区二区三区| 第一福利永久视频精品| 欧美一区视频在线| 日韩中文字幕免费视频| 成人免费淫片视频软件| 欧美日韩电影在线观看| 欧美成人黑人xx视频免费观看| 日韩欧美在线视频观看| 亚洲精品有码在线| 亚洲资源在线看| 久久影院中文字幕| 日韩精品中文字幕在线观看| 国产精品综合久久久| 欧美乱大交xxxxx另类电影| 成人夜晚看av| 日产精品99久久久久久| 欧美—级高清免费播放| 欧美日韩在线视频首页| 日韩电影大全免费观看2023年上| 色阁综合伊人av| 国产精品福利在线观看网址| 97视频在线观看视频免费视频| 96精品久久久久中文字幕| 国产精品自产拍高潮在线观看| 九九热r在线视频精品| 在线精品播放av| 姬川优奈aav一区二区| 欧美色videos| 国产91热爆ts人妖在线| 成人午夜激情网| 欧美在线视频一二三| 亚洲最大激情中文字幕| 日本亚洲欧洲色α| 久久影视三级福利片| 日韩在线观看你懂的| 久久亚洲精品毛片| 国内精品国产三级国产在线专| 91九色视频导航| 久热99视频在线观看| 91精品国产自产在线老师啪| 性欧美xxxx| 激情久久av一区av二区av三区| 成人写真视频福利网| 国产精品免费视频久久久| 亚洲欧美色婷婷| 国内精品久久久久久久| 国产精品视频资源| 尤物99国产成人精品视频| 国产精品久久久久久久久免费| 亚洲欧洲偷拍精品| 永久555www成人免费| 国产精品高清在线| 欧美国产日产韩国视频| 国产欧美久久久久久| 日韩欧美在线视频观看| 欧美最猛性xxxx| 国产精品日韩在线一区| 亚洲欧美国产一区二区三区| 久久久久久久网站| 亚洲欧美在线第一页| 国产一区二区丝袜高跟鞋图片| 日韩男女性生活视频| 日韩美女av在线| 亚洲自拍偷拍网址| 欧美精品久久久久久久| 国产精品狼人色视频一区| 亚洲精品视频在线观看视频| 欧美精品在线视频观看| 最近中文字幕日韩精品| 欧美成人免费视频| 55夜色66夜色国产精品视频| 91久久精品久久国产性色也91| 成人h视频在线观看播放| 欧美黑人又粗大| 成人黄色大片在线免费观看| 欧美成人午夜激情| 久久在线视频在线| 91久久久在线| 一道本无吗dⅴd在线播放一区| 久久久久免费精品国产| 亚洲欧美综合v| 久久久91精品国产| 国产精品视频1区| 亚洲色图av在线| 精品久久久国产精品999| 26uuu亚洲国产精品|