写出了helloWorld是一个成功开始,让我们深入学习一些相关信息吧
键盘输入,屏幕输出
键盘输入
- 我们通常使用gets方法获取键盘输入的值
name=gets #我们定义一个变量name,把键盘输入的值赋给name
puts "#{name}好漂亮"
- 发现尝试之后,只有回车才能停止输入,并且换行也被读入到name中
- 读入的数据类型我猜想是字符串,但是还是要验证一下的
puts "输入数据类型#{name.class}" #.class方法用来验证数据类型
- 但是如果我不想把换行读入,但是输入又没办法停止该怎么办?
name=gets.chomp #使用chomp方法去掉结尾换行符号
print("#{$name2},你好漂亮!")
这时候我们就是用的字符串的.chomp方法:chomp方法是移除字符串尾部的分离符,例如\n,\r等...而gets默认的分离符是\n
- 我么还可以使用ARGV数组获取数据
- 1.ARGV:其实只是一个ruby定义好的一个数组,和java中的args类似,在你使用ruby 文件名 运行文件时,在后面加上用空格分隔的几个字符串这几个字符串就被放进了ARGV数组
- 2.在代码中你可以不用定义直接使用,和一般数组使用的方式完全一致
- 屏幕输出
我们通常使用print和puts输出数据,然而他们之间区别是什么呢?
puts "zhangpei"
puts "很漂亮···" #第一种方式
print "zhangpei"
print "很漂亮···" #第二种方式
print <<EOF
zhangpei
很漂亮...
EOF #第三种方式
ps:请原谅我的自恋················
区别是:puts会在打完内容后自动换行,而print不会,但是当print使用第三种方式打印,就可以保留两个EOF之间的所有空格空行
相关Demo查看链接的inputAndOutputDemo.rb Demo,使用ruby 该文件路径
即可运行
请注意,print是一个方法,但是对于ruby而言,是否给他方法的参数添加括号并没有什么影响,但是参数最好使用括号括起来的
- 其实我们还有p这个输出方法
这种输出方法和print这种输出方式类似,但是还是有大概两种区别
1.p只会转义'别的符号他都不会转义
p("\n我是张培\t你是谁")
puts("\n我是张培\t你是谁")
2.他会把所有要输出数据都按照原来的类型输出
- ruby有一种比较方便的输出方式是js没有的
print "请输入你的名字:"
name=gets
puts name,"shi","haoren"
print name,"shi","haoren" <=> print "#{name}shihaoren"
我们可以在同一行采用逗号分隔每一个逗号代表对puts或者print的一次调用,后两中方式体现了**引入变量的方式**:
- 1.采用逗号分隔字符串与变量
- 2.直接在字符创中`#{变量名}`此方式类似于js中
```javascript
var name = "zhangpei"
console.log(`${name}`,shihaoren)
''和“”区别
都是字符串前者不会解析转义字符串,后者会解析
puts "zhangpei \n 乖孩子"
puts 'zhangpei \n 乖孩子'
条件判断语句和循环语句
- 条件判断语句:
1.if语句和js类似不过没有{}来限定边界,而是使用end结束内容
puts "请输入num1:"
num1=gets.chomp
puts "请输入num2:"
num2=gets.chomp
if num1>num2
puts "the bigger number is #{num1}"
elsif num1 == num2
puts "the two number is equal,all is #{num1}"
else
puts "the bigger number is #{num2}"
end #这个是循环的结束end
- 2.并且使用
elsif 条件
代替了js中的else if 条件
- 我们还有unless和case作为条件控制语句,以后再慢慢填充
数组
- 你可以直接用array=[]创建一个空的数组对象
- 也可以直接用 一个不存在的index运行
array[index]=5
给这个数组创造一个新的元素- 你可以直接使用
array.size
方法获取数组大小- 数组的循环
数组.each do |n| #一定要知道,这里的n是数组中的元素不是index
块内容
end
散列
- Symbol和String的异同
感觉String和Symbol及其相似,这时我们采取对比学习法
- 1.形态
- String的对象通常采用""或者''来包住一些字符,这个整体是一个字符串,也就是说当你看到双引号或者单引号就直到是字符串
- Symbol的对象通常采用:来引出一些字符,这个整体是一个Symbol,当你看到:就只到他是Symbol
- 2.用法
- String使用广泛(一般可以代替Symbol)
- Symbol通长都用于表示符号之类的,比如函数的名字你可以使用Symbol,强调的是名称,也就是说同样的名字,对应同样的数据
- 3.占用内存的区别
- String即便内容相同,只要申明就会创建不同的内存空间
- Symbol只要相同只占用同一个内存空间
Paste_Image.png
Paste_Image.png
代码中的.object_id
可以获取这个对象所占用的内存空间地址
我觉得之所以使用symbol就是为了可以省一点内存空间吧 - 散列的定义
- 你可以把散列完全理解成js中的json对象(都是使用{}包住,内容是key:value形式),
- 他们的区别定义创建方式不相同,js中的json通常采用String作为key,但是散列采用String或者Symbol作为key
- 获取散列中某个值的方式有一点不一样,json可以采用对象.key或者对象.
- 散列创建
hash1={name:"zhangpei",age:20}
hash2={:name=>"zhangpei",:age=>20} #hash1和hash2完全一样
hash1和hash2都是使用Symbol作为key的
hash3={"name"=>"zhangpei","age"=>20}
hash3采用字符串作为key
hash1[:name] #值是zhangpei
hash2[:name] #值是zhangpei
hash3["name"] #值是zhangpei
- 因此要注意:就算是第一种创建方法,也要通过:name访问,可见,我们一般支持Symbol类型作为key
- 散列循环
```ruby
hash1={name:"zhangpei",age:20}
hash1.each do |key,value|
puts "#{key}:#{value}"
先总结这么多,在接下来的简书中我可能会再细致的讲些基础语法,你可以访问我的github 里面有许多RubyDemo,可以进行进一步学习