- 调用函数时,圆括号不是必须的。
- 类名的第一个字母必须大写。类的成员变量使用@作为开头标记。类的成员变量不能被外部直接访问,也就是说所有的成员变量都是private的。
- return关键字不是函数必须的,如果忽略使用return,则函数最后一个表达式的值就是默认return的值。为了避免混淆,建议显示使用return关键字。
- initialize方法是在类的构造方法被调用完之后紧接着被调用的,所有的初始化工作都可以在这里完成。
- inspect方法可以用来洞悉对象的内部构造。p函数是inspect方法的快键方式。
- super关键字用来调用当前方法的父类方法。如果仅写super没有括号没有参数列表,那么当前方法的所有参数都传入super;如果在调用super时带有括号和参数列表,那么仅传入指定参数到super;如果在调用super时带有括号而没有参数列表,则没有参数传入super。
- 存取方法(Accessor Method)除了传统的get和set形式外,还可以写成def name end 和 def name=(aName) end这样的形式。亦可使用attr_reader、attr_write方法配合symbol创建存取方法。attr_accessor = attr_reader + attr_writer。可以一次性用attr_xxxx定义多个存取方法。
- 作用域解析标识 :: ,可以穿越作用域访问常量。
- 有类似Objective-C的Category特性,可以为一个ruby的标准类增添方法。
- ruby可以自定义字符串分隔符。%Q和%相当于双引号的作用,%q是单引号。例子,%Q[abcdefg],%q/abcdefg/。
- 使用 ` 包裹的字符串会被ruby当作操作系统的指令来执行。%x拥有同样的效果。例子,`dir`,%x/dir/。还可以这样写:puts "#{%x/dir/}"。
- 字符串的方法中已感叹号结尾的,不会返回一个新的字符串,而是代之以修改原字符串的内容
- 对象的object_id方法可以打印它的id
- ruby有一种range类型,表达方式如下 start..end 。凡是有顺序的类型都可以作为range的值。start...end,三个点表示忽略范围中最后一个值。to_a方法可以根据range创建一个数组,浮点数除外。
- 数组比较操作符 <=> ,0代表相同,-1是左边的小于右边的 1是左边的大于右边的,个人感觉没什么用。。。
- 数组可以使用clone方法进行浅层复制。对于数组来说,不仅仅是感叹号结尾的方法会修改自身数据,例如 << clear delete 等都会修改数组自身而不是返回一个修改后的copy。
- 数组有 & + - << 等符号作集合运算。数组的flatten方法可以平面化数组元素。
- Comparable模块可以为自定类型提供比较方法。写法 include Comparable
- ruby中的hash就是其他语言中map或者dict这样的类型。Hash.new(something)可以为hash提供一个索引默认值,在没有索引的情况下,返回这个默认值。如果Hash.new则不提供默认值。在hash找不到匹配索引时,返回nil。 Hash的快捷创建方式 { 'a' => 1, 'b' => 2 }。hash.default可以存取默认值。
- Hash的sort方法,其返回值是hash内部的一个数组表示。