1。交互方式运行ruby输入ruby后直接写代码,最后按Ctrl+D表明结束;另外能够用irb(Interactive Ruby)来执行交互编程。运行本地的ruby程序分两步,一用irb load进xxx.rb,二而后运行这个文件中的方法。css
2。ri是一种本地命令行工具,用来浏览RDoc文档。java
3。方法是经过向对象发送消息唤起调用的,消息中包含方法名和方法可能须要的参数。编程
4。ruby中获得数字绝对值方法:-123.abs既可,但java和其它语言中则是传给其它函数如:Math.abs(-123);这说明ruby是面象对象的。数组
5。ruby方法定义和调用是能够不加(),但为了可读和优先级,最好加上()。表达示内插#{name}。ruby
6。全局变量:$xxx;类变量@@xxx;实例变量:@xxx。局部变量、方法参数、方法名必须以小写字母或下画线开始;类名称、模块名称和常量都必须以一个大写字母开始。方法名能够?!=结尾。闭包
7。ruby数组和散列表都用来存储对象,只是所用的键不同。函数
8。nil是一个对象,不像别的语言中的null,是只这个对象表示什么也没有的对象。工具
9。使用语句修饰符至关于把if/while的条件和执行语句益交换了。学习
10。block是与方法调用放一块儿的,入在方法调用最后,相似传入方法的参数,能够实现回调。使用yield语句实现回调。yield(xxx,xxx)支持传参数,在block中使用|xxx,xxx|引用参数。例:5.times { puts "a"}ui
11。ruby中会有许多内置的变量,如$_ 。
12。ruby的构造器为initialize。
13。ruby中已定义的类能够随时修改,而且修改能够反应当已经实例化的对象中?
14。类和子类定义:class Parent [code] end class Sub < Parent [code] end。super关键字用来调用父类中的同名方法。而且ruby中大部分方法都有返回值,由于一个方法的最后一后默认前面加了一个return。def name @name end至关于getXXX,简化方法为attr_reader :name, :age这种方式创相似的建getXXX方法。而且会自动建立冒号后面的变量。def name=(n) @name = n end,既定义一个等号结尾的方法名,能使其出如今赋值操做左侧。简洁方法:attr_writer :name。虚拟方法的概念:就是实例方法名和调用时所用的方法名不一样。
15。类变量@@开头,而且必须实用前要实例化。类方法定义方法为类名加点号加方法名,如Song.classMethod。
16。ruby方法访问权限有三种:public,protected和private。方法默认是public的(initialize方法除外,默认为private的);private的方法接收者只能是self。ruby的访问控制是在运行期间确实而非静态断定。
17。变量不是对象,默认的是局部变量。对象复制person.dup,对象冻结person.freeze 。
18。数组用法有a[1,3],a[1...3] = [xxx]等,中间部分自动添nil。
19。执行block传参数时,若是将方法中(不只仅是方法,还能够是周围的其它环境)的变量传入block块,block操做结果对其产生影响到。block最后一条表达式的值将做为返回值返回给调用的方法。block可作事务处理,也可被用做闭包。
20。迭代方法有each,find,inject,collect。ruby中为内部迭代器,java中为外部迭代器,其实,迭代器本质上是迭代器模式,有内外之分。
21。method(*args) 中*args为可变数组。定义方法时加def method(&action) action.call(self) end则方法调用时会寻找block,也就是说这个方法要和block块配合使用。
22。字符串能够%q,%Q分隔符来实现,还能够用here documents实现。
23。ruby用区间实现序列、条件和间隔。..表明闭合区间,...表明左闭右开区间。区间在内存中被表示为Range对象而不是全部的list,能够用to_a转为list。<=>比较符根据大小返回-1,0,1。succ方法指向区间的下个对象,一个类实现了succ方法和<=>就能够作为区间。区间能够作为条件。区间能够作为间隔,判断一些值是否落入区间内。如(1..10) === 5。
24。查询用的方法一般以?结尾,赋值的用=结尾,危险的方法用!结尾。定义方法时*号表示可变参数;调用方法时*号表示数组展开。方法&表示关联的block会转化为Proc对象做为方法的参数。方法总会返回最后一个表达式的值。
25。ruby并行赋值a,b = 2,3。方法返回多个值不会出错,是以数组形式返回。如:return n,m。
yum install ruby yum install ruby-irb
而后ruby -v
能够查看Ruby版本,直接irb
就能够进入irb了,它是Ruby的交互式解释器。
‘=>’后面给出的是返回值。
[lzh@hostlzh /]$ irb
irb(main):001:0> a=3
=> 3 irb(main):002:0> b=2.13 => 2.13 irb(main):003:0> a**b => 10.3816951625648 irb(main):004:0> exit [lzh@hostlzh /]$
ruby的脚本文件后缀名是.rb。
[lzh@hostlzh /]$ cd /home/lzh/文档/Ruby/ [lzh@hostlzh Ruby]$ touch 1.rb [lzh@hostlzh Ruby]$ gedit 1.rb
第一行仍是要指明解释器在哪,看一下:
[lzh@hostlzh /]$ which ruby /usr/bin/ruby
书写.rb脚本文件:
#!/usr/bin/ruby print("your name? ") name=gets() puts("Hello,#{name},emmm") puts("Bye,#{name},6666")
用解释器执行:
[lzh@hostlzh Ruby]$ ruby 1.rb your name? lzh Hello,lzh ,emmm Bye,lzh ,6666 [lzh@hostlzh Ruby]$
能够看到print是不换行的,puts是换行的。可是gets()方法会把换行符一块儿读进来!因此#{name}取name的值输出出来是带换行的。
Ruby语法极其自由,如写成:
#!/usr/bin/ruby print "your name? " name=gets puts "Hello,#{name},emmm" puts "Bye,#{name},6666"
也同样跑:
[lzh@hostlzh Ruby]$ ruby 1.rb your name? SB Hello,SB ,emmm Bye,SB ,6666 [lzh@hostlzh Ruby]$
(函数在不须要参数并且没有歧义时括号能够不要)
可是为了减小学习Ruby和学习Python3的成本,我仍是都打上的好吧。
Python的哲学就是”作一件事只有一种方法”,而Ruby与之彻底相反,推崇用多种方法来解决问题,这也致使了Ruby工程难以多人共同协做。
Ruby是纯粹的面向对象,这是吸引我学习Ruby的一个重要方面(体会一下其它语言中存在的问题),还有想试试Ruby的语法糖。
脚本的一大特性就是应当能直接接受来自命令行的输入,命令行的输入按顺序称为变量ARGV[i],能够像使用其它变量那样使用它。
#!/usr/bin/ruby puts("第一个参数=#{ARGV[0]},第二个参数=#{ARGV[1]}")
[lzh@hostlzh Ruby]$ ruby 1.rb lzh sb 第一个参数=lzh,第二个参数=sb [lzh@hostlzh Ruby]$
标准输入在键盘,标准输出在显示器。
gets其实是STDIN的gets()方法:
#!/usr/bin/ruby name=STDIN.gets() puts("Hello,#{name},SB")
[lzh@hostlzh Ruby]$ ruby 1.rb LZH Hello,LZH ,SB [lzh@hostlzh Ruby]$
(哇,真的很OOP)
gets()会留下换行符号的,若是不想要,再.chomp()一下:
#!/usr/bin/ruby name=STDIN.gets().chomp() puts("Hello,#{name},SB")
[lzh@hostlzh Ruby]$ ruby 1.rb LZH Hello,LZH,SB [lzh@hostlzh Ruby]$
puts其实是STDOUT的puts()方法:
#!/usr/bin/ruby name=STDIN.gets().chomp() STDOUT.puts("Hello,#{name},SB")
[lzh@hostlzh Ruby]$ ruby 1.rb LZH Hello,LZH,SB [lzh@hostlzh Ruby]$
若是不要尾接换行符,用STDOUT的print()方法:
#!/usr/bin/ruby name=STDIN.gets().chomp() STDOUT.print("Hello,#{name},SB")
[lzh@hostlzh Ruby]$ ruby 1.rb LZH Hello,LZH,SB[lzh@hostlzh Ruby]$
Ruby提供了相似C语言的格式化输出方法,也是使用占位符:
#!/usr/bin/ruby name=STDIN.gets().chomp() STDOUT.printf("Hello,%s,SB%d",name,1)
[lzh@hostlzh Ruby]$ ruby 1.rb lzh Hello,lzh,SB1[lzh@hostlzh Ruby]$
也即文件读写,在这以前,先写点东西到文件里:
[lzh@hostlzh Ruby]$ ll -h>tst
看一下:
[lzh@hostlzh Ruby]$ cat tst
总用量 32K
-rw-rw-r--. 1 lzh lzh 63 1月 27 13:32 1.rb -rw-rw-r--. 1 lzh lzh 64 1月 27 13:31 1.rb~ -rw-rw-r--. 1 lzh lzh 1.1K 1月 26 19:52 first.rb -rw-rw-r--. 1 lzh lzh 1.1K 1月 26 19:52 first.rb~ -rw-rw-r--. 1 lzh lzh 150 1月 27 00:23 MyFileSys -rw-rw-r--. 1 lzh lzh 15 1月 26 23:32 MyFileSys~ -rw-rw-r--. 1 lzh lzh 408 1月 27 00:50 sy4.rb -rw-rw-r--. 1 lzh lzh 405 1月 27 00:50 sy4.rb~ -rw-rw-r--. 1 lzh lzh 0 1月 27 13:36 tst [lzh@hostlzh Ruby]$
最经常使用的是File的open()方法。
#!/usr/bin/ruby file=File.open("./tst", "r") while (line=file.gets())!=nil STDOUT.print(line," 666 66 6 ") end file.close()
Ruby中不强制缩进,因此循环这样的语句块须要有end结束。
nil是Ruby中的一个特殊值,表示对象不存在,固然在这里能够把!=nil
去掉。
用于简单I/O的方法也可用于全部有权限的文件对象,因此能够用line=file.gets()
读入文件中的一行,而且带有换行符。
[lzh@hostlzh Ruby]$ ruby 1.rb 总用量 32K 666 66 6 -rw-rw-r--. 1 lzh lzh 63 1月 27 13:32 1.rb 666 66 6 -rw-rw-r--. 1 lzh lzh 64 1月 27 13:31 1.rb~ 666 66 6 -rw-rw-r--. 1 lzh lzh 1.1K 1月 26 19:52 first.rb 666 66 6 -rw-rw-r--. 1 lzh lzh 1.1K 1月 26 19:52 first.rb~ 666 66 6 -rw-rw-r--. 1 lzh lzh 150 1月 27 00:23 MyFileSys 666 66 6 -rw-rw-r--. 1 lzh lzh 15 1月 26 23:32 MyFileSys~ 666 66 6 -rw-rw-r--. 1 lzh lzh 408 1月 27 00:50 sy4.rb 666 66 6 -rw-rw-r--. 1 lzh lzh 405 1月 27 00:50 sy4.rb~ 666 66 6 -rw-rw-r--. 1 lzh lzh 0 1月 27 13:36 tst 666 66 6 [lzh@hostlzh Ruby]$
另外,也可使用File.new()方法,传入相同的参数打开文件,但File.new()不能跟块关联。在这个例子里没有区别。
#!/usr/bin/ruby file=File.new("./tst", "r") while (line=file.gets())!=nil STDOUT.print(line," 666 66 6 ") end file.close()
输出是同样的。
打开文件后,也能够用sysread()方法指定从当前文件指针向后读多少个字符。
#!/usr/bin/ruby f=File.open("tst","r") if f!=nil str=f.sysread(40) #读入40个字符后,文件指针在第41个字符位置 STDOUT.puts(str) else STDOUT.puts("没能成功打开文件") end f.close()
[lzh@hostlzh Ruby]$ ruby 1.rb 总用量 32K -rw-rw-r--. 1 lzh lzh 63 [lzh@hostlzh Ruby]$
能够用IO.readlines()方法读入指定文件的每一行到数组中,不会自带换行符。也不涉及打开文件和文件指针等问题。
#!/usr/bin/ruby arr=IO.readlines("tst") STDOUT.puts(arr[0]) STDOUT.puts(arr[1]) STDOUT.puts(arr[3]) STDOUT.puts(arr[1])
[lzh@hostlzh Ruby]$ ruby 1.rb
总用量 32K
-rw-rw-r--. 1 lzh lzh 63 1月 27 13:32 1.rb -rw-rw-r--. 1 lzh lzh 1.1K 1月 26 19:52 first.rb -rw-rw-r--. 1 lzh lzh 63 1月 27 13:32 1.rb [lzh@hostlzh Ruby]$
方法IO.foreach()之于方法IO.readlines(),就如方法File.open()之于方法File.new()。前者都是能够跟块关联的,块具体怎么用后面再学。
#!/usr/bin/ruby IO.foreach("tst"){|line| puts line}
[lzh@hostlzh Ruby]$ ruby 1.rb
总用量 32K
-rw-rw-r--. 1 lzh lzh 63 1月 27 13:32 1.rb -rw-rw-r--. 1 lzh lzh 64 1月 27 13:31 1.rb~ -rw-rw-r--. 1 lzh lzh 1.1K 1月 26 19:52 first.rb -rw-rw-r--. 1 lzh lzh 1.1K 1月 26 19:52 first.rb~ -rw-rw-r--. 1 lzh lzh 150 1月 27 00:23 MyFileSys -rw-rw-r--. 1 lzh lzh 15 1月 26 23:32 MyFileSys~ -rw-rw-r--. 1 lzh lzh 408 1月 27 00:50 sy4.rb -rw-rw-r--. 1 lzh lzh 405 1月 27 00:50 sy4.rb~ -rw-rw-r--. 1 lzh lzh 0 1月 27 13:36 tst [lzh@hostlzh Ruby]$
打开的文件对象的syswrite()方法能够向文件写入内容,写入的方式取决与打开时的写方法。
r+形式的读写模式文件指针会放在开头,写的内容会随指针移动覆盖以前的内容:
#!/usr/bin/ruby f=File.new("tst","r+") if f!=nil f.syswrite("LZH\nSBSBSBSBSSB\nSBBBBB") else STDOUT.puts("没法获取文件对象") end f.close()
[lzh@hostlzh Ruby]$ ruby 1.rb
[lzh@hostlzh Ruby]$ cat tst
LZH
SBSBSBSBSSB
SBBBBB--. 1 lzh lzh 63 1月 27 13:32 1.rb
-rw-rw-r--. 1 lzh lzh 64 1月 27 13:31 1.rb~ -rw-rw-r--. 1 lzh lzh 1.1K 1月 26 19:52 first.rb -rw-rw-r--. 1 lzh lzh 1.1K 1月 26 19:52 first.rb~ -rw-rw-r--. 1 lzh lzh 150 1月 27 00:23 MyFileSys -rw-rw-r--. 1 lzh lzh 15 1月 26 23:32 MyFileSys~ -rw-rw-r--. 1 lzh lzh 408 1月 27 00:50 sy4.rb -rw-rw-r--. 1 lzh lzh 405 1月 27 00:50 sy4.rb~ -rw-rw-r--. 1 lzh lzh 0 1月 27 13:36 tst [lzh@hostlzh Ruby]$
w只写模式,或者w+形式的读写模式,都会重写已经存在的文件,或者是新建并未存在的文件。
#!/usr/bin/ruby f=File.new("tst","w+") if f!=nil f.syswrite("怎么还不放假\n确实 强啊\t666") else STDOUT.puts("没法获取文件对象") end f.close()
[lzh@hostlzh Ruby]$ ruby 1.rb [lzh@hostlzh Ruby]$ cat tst 怎么还不放假 确实 强啊 666[lzh@hostlzh Ruby]$
和C语言很像,sprintf()方法能够格式化输出给字符串,固然普通的不须要占位符的也能够用这个方法,因此只有这一个而没有什么”sputs()”这样的方法。
#!/usr/bin/ruby name=STDIN.gets().chomp() str=sprintf("Hello,%s,SB%d",name,1) STDOUT.puts(str)
[lzh@hostlzh Ruby]$ ruby 1.rb 1221assad Hello,1221assad,SB1 [lzh@hostlzh Ruby]$