整型的字面量可以写成下面的几种形式:
一个10进制数字,没有前缀。比如17代表10进制的17
一个2进制的数字,用0b作为前缀。比如0b10001代表10进制的17
一个8进制的数字,用0o作为前缀。比如0o21代表10进制的17
一个18进制的数字,用0x作为前缀。比如0x11代表10进制的17
浮点数的字面量可以是10进制小数或者16进制的小数(用0x作为前缀)。浮点数字面量在小数点两边都必须有数字。10进制的浮点数也可以有一个指数,用一个大写或者小写的e来表示。16进制的浮点数必须有一个指数,用大写或者小写的p来表示
一个有指数的10进制小数,是基数乘以10的X次方, 比如:
1.25e2 == 1.25*10^2 == 125
1.25e-2 == 1.25*10^-2 == 0.0125
一个有指数的16进制的小数,是基数乘以2的X次方,比如:
0xFp2 == 15 * 2^2 == 60.0
0xFp-2==15 * 2^-2 == 3.75
以下所有的浮点数字面量的值都等于12.1875
12.1875==1.21875e1==0xC.3p0
数值的字面量可以包含其他的格式符使其更加易于阅读。整型和浮点数都可以加入额外的0,也可以包含下划线来增强可读性。格式符并不会影响字面量代表的数值。
let paddedDouble = 000123.456
let oneMillion = 1_000_000
let justOverOneMillion = 1_000_000.000_000_1
数值类型转换(Numeric Type Conversion)
通常情况下,请使用Int类型表示整型数的常量或者变量,即使你知道它们必然是非负数。在所有情况下使用默认的Int类型的整型常量或者变量是有好处的,这可以让这些整型数之间在任何地方可以随意操作组合(类型一样),所推断出来的整型类型也会匹配。
除非你手上的工作对整型有特定的要求,比如外部数据有固定的位数,对性能,内存,或者是基于其他必要的优化。在这些情况下使用有明确位数的整型类型,有助于发现偶尔的值溢出的情况,以及隐式的记录被内在的使用的值。
整型转换(Integer Conversion)
一个整型变量或者常量可以存储的数值的范围和其具体的整型类型有关,Int8类型的常量或者变量可以存储的数值类型是[-128,127],一个UInt8类型的常量或者变量可以存储的数值类型是[0,255]。在编译过程中,如果数值已经不匹配该整型类型的可以储存数值的范围,将会报错:
let cannotBeNegative: UInt8 = -1 //无法存储负数,会报错
let tooBig: Int8 = Int8.max + 1 //无法存储大于可以存储的最大值的值,会报错
由于每一个数值类型可以存储不同范围的值,你必须选择根据实际情况分析和选择需要转换的数值类型。这可以防止存在隐藏的转换错误,使在代码中可以更加明确的表达出类型转换的意图。
为了把一个特定的数值类型的值转化为另外一个,你需要使用已经存在的值初始化一个目标类型的值。
let twoThousand: UInt16 = 2_000
let one: UInt8 = 1
let twoThousandAndOne = twoThousand + UInt16(one)
上面的例子中,常数twoThousand的类型是UInt16,one的类型是Uint8,他们无法直接相加,因为类型不一样。所以,例子中调用UInt16(one)方法,使用one的值去初始化了一个新的UInt16类型的值,并且使用这个新的UInt16类型的值进行操作。现在,twoThousand和UInt16(one)都是UInt16类型的值了,所以他们相加是被允许的。可以推断出结果twoThousandAndOne也是UInt16类型的,因为加号两边的数都是UInt16类型的。
SomeType(ofInitialValue)是Swift默认提供的构造器,用于使用初始值去初始化某一个类型的值。往深层次了看,其实UInt16类型提供了一个可以接受UInt8类型的值的构造器,这个构造器的作用就是使用一个UInt8类型的值去构造一个UInt16的值。但论这个构造器而言,你不可以传入UInt8类型的值之外的其他类型的值,也就是说,必须是UInt16类型提供的构造器所要求的类型。若要给一个已经存在的类型增加新的构造器,支持新的类型,可以看一下Extension。
整型和浮点数的转换
整型和浮点数类型之间的转换必须要有很明确的表达。
let three = 3
let pointOneFourOneFiveNine = 0.14159
let pi = Double(three) + pointOneFourOneFiveNine
上面的例子中,使用常数three用来创建了一个新的Double类型的值,因此,在加号两边都是Double类型,如果没有进行正确的类型转换,这个加法操作是不被允许的。
同样的,浮点数转换为整型数也是需要明确表达的。可以使用一个Double类型的值或者一个Float类型的值去初始化一个整型数:
let IntegerPi = Int(pi) // IntegerPi == 3
用这种方法使用浮点数去初始化一个新的整型数,总是会截断小数部分,也就是说,4.75变成4,-3.9变成-3。
NOTE:数字类型的变量或者常量的组合和数字字面量的组合是不一样的,整型字面量的3可以直接和Double字面量0.14159相加,因为数字的字面量本身并没有确切的类型。他们的类型只会在被编译器赋值的时候才会被推断出来。
网友评论