今天闲来没事,继续学习ruby,从javaeye上看到一篇好贴子,留作私有。
--------------------------------------------------------------------------------
Ruby有不少惯用法,这里略作一些介绍,也方便阅读他人代码:
迭代
一般写法:
代码
for i in (1..10)
puts i
end
习惯写法:
代码
(1..10).each{|i| puts i}
或
1.upto(10){|i| puts i} # from njmzhang
||=赋值
一般写法:
代码
number = 1 if number.nil?
number = 1 unless number
习惯写法:
代码
number ||= 1
程序入口
代码
if __FILE__ == $0
或
if $PROGRAM_NAME == __FILE__
这个相当于main(), 逻辑判断的意思当程序名($0或另一个)和当前文件名(__FILE__)一致时,也就是当前文件是被单独执行的而不是被别的文件调用。这个方法还有个用法是作为unit test使用。
预设变量和特殊记号
类似$0的Perl风格预设常量还有很多,参见Programming Ruby p319
其中比较常用的如$:代表库搜索路径,修改方法常见有:
代码
$:.unshift('buildscript') # from gigix
或
$: << File.join(File.dirname(__FILE__), 'CurrentClass')
后一种方法使用了相对路径,因为Ruby的module不要求namespace和文件目录结构要对应一致,很多时候统统放一个目录里
%w格式化命令(from qiezi) 可以少打几个引号
代码
%w{a b c d} #等价 ['a', 'b', 'c', 'd']
``(~键下的撇号)用来执行shell外部命令,如:
代码
`help`
inject
一般写法:
代码
result = []
(1..10).each{|item| result << item}
习惯写法:
代码
(1..10).inject([]){|array, item| array << item}
inject有点难理解,相当于python的reduce和一些FP里的fold。inject的块变量有两个(这里是array和item),第二个变量(item)用来枚举被inject的集合(这里是(1..10)这个range), 而第一个变量(array)由inject的参数初始化(这里是[],可选),并在block被反复执行时保持持久(相当于静态变量),而item则在每次枚举时被更新为下一个值。我们再看一下inject的另一种通常用法就会更明白了:求和
代码
(1..10).inject{|sum, item| sum += item}
这个等于
(1..10).inject(0){|sum, item| sum += item}
也就是块变量sum被初始化成0然后反复迭代执行块的内容,最后返回sum
并行赋值
这个很多人都知道了,比如:
代码
a,b = 0, 1
a,b = b, a # 交换a,b
当然可以延伸出一些很诡异的变化,不提倡使用阿
还有一个用法是让函数返回“多个结果”(不是多个对象),如:
代码
def test
1,2
end
x, y = test #x = 1, y = 2
这个njmzhang说的很对,其实函数返回的是一个array,然后再并行匹配到变量上去。(所以我对多个结果特别加了引号)
这显然是个syntax sugar,你随便用逗号分割几个变量是不会自动组成array的。
注意这种并行匹配当两遍不平衡时会造成的问题:
代码
a,b = [1,2,3] # a = 1, b = 2, 3被丢弃
a,b,c = [1,2] # a = 1, b = 2, c = nil 被初始化成nil
*的匹配
一般来说*用于把一个array展开:
代码
a, *b = [1,2,3] #a = 1, b = [2,3]
类似FP里的x:xs(haskell), x::xs(ocaml), [a | b] (erlang from 布娃娃)
rescue简单用法
代码
begin
1/0
rescue
puts 'wrong'
end
可以简化为
代码
1/0 rescue puts 'wrong'
命名参数的默认值
ruby有默认参数,但其实没有所谓keyword argument,而是提供一个syntax sugar用hash模拟。但是怎么像Rails的方法那样同时利用命名参数和默认参数值呢?
代码
def image(opt={})
default_opt = {:height => 25, :width => 10}
default_opt.merge! opt #opt中同样key的内容会覆盖default_opt中key的value
end
精细duck typing控制
duck typing的精神就是行为决定类型,而不是相反
代码
a = []
#不用
if a.kind_of? Array then a << 1
if a.instance_of? Array then a << 1
#而用
if a.respond_to? :<< then a << 1
获取metaclass
这也比较常见了,各种动态伎俩的开始
代码
sing = class << self; self; end
符号转换到Proc
一般写法:
代码
(1..10).map{|item| item.succ}
习惯写法:
代码
(1..10).map(&:succ)
map(fun(x))般的FP风格
注意这是Rails特有的,通过ActiveSupport对Symbol插入to_proc方法。
不用Rails怎么办呢?一种办法是借助Ruby Facets库(gem install facets):
代码
require 'facet/symbol/to_proc‘
Facets库包括大量对Ruby核心类的扩展,是个有趣而又危险的大杂烩,也许我以后会另外再专门介绍一下。
分享到:
相关推荐
### Ruby惯用法详解 #### 一、简介 Ruby是一种简单快捷的面向对象的脚本语言,具有丰富的类库和简洁的语法结构。在实际开发过程中,为了提高代码的可读性和可维护性,Ruby社区形成了一系列约定俗成的惯用法(idioms...
在Ruby社区中,惯用法(idioms)和最佳实践(best practices)是提高代码质量的关键。本文将深入探讨Ruby中的关键技巧、重构方法以及遵循的代码风格指南。 一、Ruby技巧 1. 块和迭代器:Ruby中的块(blocks)和...
在讲述Ruby知识的过程中,始终从Rails开发实战出发,揭示Rails和Puby之间的微妙关系,阐述Rails自身特有的技术、惯用法和设计理念,并用Rails开发了一个网上音乐店实例。最后还介绍了探索Rails源代码的各种技术,为...
1. **Ruby idioms**:书中将深入探讨Ruby的惯用法,这些是让代码更简洁、更具Ruby风格的关键。 2. **编程技巧**:如何利用Ruby的特性编写出高效且易于维护的代码,如上下文敏感的语法糖和内建函数的巧妙使用。 3. ...
6. 惯用法和语言扩展:书中还可能会介绍Ruby中的惯用法,以及如何通过元编程进行语言扩展和自定义。这些高级特性是Ruby语言灵活多变的重要原因,也是使Ruby成为一门值得学习的语言的关键特性之一。 7. 历史影响:...
通过学习Ruby,开发者可以更容易地理解和运用这些惯用法。 - **扩展性**:Ruby的强大之处在于其高度的灵活性和可扩展性。掌握了Ruby,开发者就能够根据自己的需求灵活地扩展Rails的功能,创造出更加符合业务场景的...
4. Rails技术、惯用法和设计理念:本书还涵盖了Rails特有的技术点、编程惯用法以及Rails的设计哲学,这些都是构建Rails应用时不可忽视的重要方面。 5. 实战项目:作者通过构建一个网上音乐店的实例来展示如何使用...
它实现了一种以声明方式编写某些类型的代码的惯用法。 特别是,这是为了使Rails控制器和视图更整洁。 安装BasicAssumption 这是一颗宝石,通常也是如此: [sudo] gem install basic_assumption 在Rails应用程序...
3. **惯用法(Idiomatic)**:在编程领域,惯用法是指在特定编程语言或社区中广泛接受的最佳实践,它有助于保持代码的一致性和可读性。 4. **Sublime Text**:Sublime Text是一款流行的文本编辑器,以其速度、简洁...
2. **构架建模惯用法**:为了确保构架模型的一致性和清晰性,通常会采用一套固定的建模惯用法。例如,在用例视图中,用例通常会被命名为描述性的动作短语,以便于理解其功能。 #### 八、结论 综上所述,技术框架在...
5. **C抽象惯用法**:在C语言中,有一些约定俗成的做法可以帮助提高代码的可读性和可维护性。 6. **C的抽象范式之OOP**:虽然C语言本身不支持面向对象编程,但可以通过指针等机制来模拟OOP的概念。 7. **C的观点:...