Ruby中的数字类型(转)
整型
Ruby 支持整型和浮点型两种数字类型。
整型可以是任意长度(最大值由你机器的内存大小决定)。在内部由两个类来表示Fixnum和Bignum,Fixnum的表数范围较Bignum小,大小超过Fixnum范围的整数由Bignum表示,如果两个Fixnum计算之后结果超出范围,则自动转换为Bignum;相反,如果两个Bignum操作结果很小,则会转换为Fixnum。Ruby在两者之间自动转换,对用户来说是透明的。
num = 10
5.times do
print num.class, " ", num, "\n"
num *= num
end
#结果
Fixnum 10
Fixnum 100
Fixnum 10000
Fixnum 100000000
Bignum 10000000000000000
Fixnum有立即值(immediate value),就是说它们当参数传递时,是值传递,而不是引用传递。赋值语句不会在变量和对象之间建立引用关系。Bignum则不是这样的,不是立即值,属于引用传递。
这两个类共有的一些方法:
A.算术操作(加减乘除自不必说):
irb(main):053:0> 5/2 # 整数
=> 2
irb(main):054:0> 5%2 #取模 ,即余数
=> 1
irb(main):055:0> 2**4 #2的4次幂
=> 16
B.位操作:
|
按位与
&
按位或
^
按位异或
>>
右移
<<
左移
1的二进制为:00000001
2的二进制为:00000010
irb(main):056:0> 1&2
=> 0
irb(main):057:0> 1|2
=> 3
irb(main):058:0> 1^2
=> 3
irb(main):059:0> 1<<1
=> 2
irb(main):060:0> 2>>1
=> 1
irb(main):061:0>
C.<=> 操作符
根据<=>两边的值比较大小的结果返回-1,0,1三个值之一:
irb(main):004:0> 5<=>9
=> -1
irb(main):005:0> 5<=>5
=> 0
irb(main):006:0> 5<=>2
=> 1
D.[ ] 操作符
比如f是一个整数,则f[n]返回这个f的二进制格式的第n位的值,为0或者1。
E.size:返回这个整数占用的字节数
irb(main):007:0> 1.size
=> 4
irb(main):008:0> 100000000.size
=> 4
irb(main):009:0> 1000000000000000000000000000.size
=> 12
F.to_f:返回这个整数的浮点值,其实就是加一个”.0”。
to_s:返回这个整数的字符串。
irb(main):010:0> 102.to_f
=> 102.0
irb(main):011:0> 102.to_s
=> "102"
irb(main):012:0>
同样,你也可以在数字前面使用进制标识符,比如0表示八进制,0x表示十六进制,0b表示二进制等。而且,如果一个整型数字中有一个下划线,这个下划线将被忽略。(但是下划线不能在开头或者结尾)
irb(main):061:0> 1_2*2
=> 24
irb(main):062:0>
类 Iteger
类Integer是Fixnum和Bignum的父类,有一些特殊的方法:
chr(integer):返回这个数字代表的ascii值。
downto(integer):接收一个block,进行从大到小的循环执行block。
anInt.next:返回anInt的下一个数(即anInt+1)。
anInt.Step(endNum,step):从anInt循环到endNum,步长为step,而不是1。
int.times {| i | block } 循环int次,每次执行block中的语句。
upto:类似downto。
irb(main):014:0> 1.next
=> 2
irb(main):015:0> 65.chr
=> "A"
irb(main):016:0> 5.downto(2){|i| puts i}
5
4
3
2
=> 5
irb(main):017:0> 2.upto(5){|i| puts i}
2
3
4
5
=> 2
irb(main):018:0> 3.times {|i| puts i}
0
1
2
=> 3
irb(main):019:0>
浮点型
Ruby中浮点数只有Float类。除了算术加减乘除,还有一些特殊方法。以下以anFloat为消息接收者。
ceil : 返回比anFloat大的最小的整数。
floor :返回比anFloat小的最大整数。
finite? :如果anFloat是一个符合IEEE格式的浮点数,返回true。(这个方法名以问号结尾)。
infinite?:根据anFloat是否是负无穷,有限浮点数,正无穷,返回-1,nil,1。
nan? :如果anFloat不是一个符合IEEE标准的数,则返回true。
round :对anFloat四舍五入到一个整数。
to_i :返回anFloat截掉小数点后面数字的整数。
irb(main):026:0> (-2.9234).ceil
=> -2
irb(main):027:0> (2.9234).ceil
=> 3
irb(main):028:0> (2.9234).floor
=> 2
irb(main):029:0> (-2.9234).floor
=> -3
irb(main):030:0> (-2.9234).round
=> -3
irb(main):031:0> (2.9234).round
=> 3
irb(main):032:0> (2.9234).to_i
=> 2
irb(main):033:0> (-2.9234).to_i
=> -2
irb(main):034:0> a=-1.0
=> -1.0
irb(main):035:0> a.nan?
=> false
irb(main):040:0> (0.0).infinite?
=> nil
irb(main):041:0> (-1.0/0.0).infinite?
=> -1
irb(main):042:0> (+1.0/0.0).infinite?
=> 1
irb(main):043:0>
|