泊学Swift系列之Swift Up and Running——整数和浮点数

Swift Up and Running——整数和浮点数

泊学原文

泊学技法视频

Swift里,数字分为整数(例如:1 / 10 / 100/ 1000等)和浮点数(例如:3.14 / 1.44 / 2.71等)。我们先来看整数。


整数 - Int & UInt

根据一个整数变量占据的内容空间(8 / 16 / 32 / 64-bit)以及整数是否带有符号(Unsinged),Swift一共定义了8种不同的整数类型:

Int8 Int16 Int32 Int64
UInt8 UInt16 UInt32 UInt64

第一行的四个类型,分别表示8 / 16 / 32 / 64-bit的有符号整数,第二行则是对应的无符号整数类型。

但通常,我们不会直接在代码中使用这些具体的整数类型,我们只使用Int来定义有符号整数,使用UInt来定义无符号整数。Swift编译器会根据目标编译平台,把Int或UInt转换成对应的整数类型。例如:

在我们的64位平台上,我们分别使用min和max方法,来查看Int和Int64可以表达的数值范围:

Int.min
Int.max

Int64.min
Int64.max

  

通过上面的对比,我们就能发现,Int和Int64,它们可以表达的数值范围,是一样的。


整数的常用表达方式

在Swift里,我们可以使用多种方式来表达一个整数。包括使用10进制、16进制、8进制、2进制:

//: Number literal

let fifteenInDecimal = 15
let fifteenInHex = 0xF
let fifteenInOctal = 0o17
let fifteenInBinary = 0b1111

  

以及,我们可以在数字中,使用分隔符:

//: Number literal
let million = 1_000_000

  

“除非我们所在的硬件平台有特别明确的需求需要我们使用UInt来定义无符号整数, 我们总是应该尽可能使用Int来表达所有的整数类型,哪怕我们确定一个整数一定是一个非负数。 这会给我们减少很多不必要的类型转换的麻烦。”

最佳实践


浮点数 Float & Double

在Swift里,根据可以表达的精度范围,有两种不同的浮点数类型:

  • Float: 最多表达6位精度的浮点数;
  • Double: 至少可以表达15位精度的浮点数;

我们用print分别打印Float和Double:

var oneThirdInFloat: Float = 1/3
var oneThirdInDouble: Double = 1/3

print(oneThirdInFloat)
print(oneThirdInDouble)

  

除了使用常规的十进制表达浮点数之外,我们还可以使用科学计数法。例如,表示浮点数PI:

var PI = 0.314e1
PI = 314e-2

  

“如不是有明确的需求,我们应该统一使用Double来定义浮点数。”

最佳实践


和数字有关的Type Inference

在Swift里,我们使用一个整数,编译器会把它推导成Int,使用一个浮点数,编译器会把它推导成 Double,例如:

var three = 3
three.dynamicType

var zeroPointForteen = 0.14
zeroPointForteen.dynamicType

  

我们可以使用dynamicType来查看一个变量的类型,从上面的结果我们就可以看到three的类型是Int, zeroPointForteen的类型是Double。

在Swift里,我们可以把不同类型数字的字面值直接进行运算:

PI = 3 + 0.14
PI.dynamicType

  

我们可以看到,整数值3和浮点数0.14可以直接相加,Swift把相加的结果转换成一个Double。

但是,在Swift里,我们不能把不同数字类型的变量直接进行算数运算,例如:

PI = three + zeroPointForteen

  

当对变量进行算数运算的时候,所有变量的类型必须是相同的,如果变量类型不同,我们必须明确将其中的一些变量进行类型转换。像这样:

PI = Double(three) + zeroPointForteen

  

从上面的代码可以看到,我们使用:

Double(Value)

把一个Int类型的three,"转换"成了浮点数。在这里,之所以我们要对转换加引号,是因为我们并没有真的把three的类型从Int转换成Double,而是用three的值,初始化了一个新的值为3的Double,并用这个新的Double和zeroPointForteen相加。

时间: 2024-10-16 03:40:52

泊学Swift系列之Swift Up and Running——整数和浮点数的相关文章

Swift语言指南(三)--语言基础之整数和浮点数

整数 整数指没有小数的整数,如42,-23.整数可以是有符号的(正数,零,负数),也可以是无符号的(正数,零). Swift提供了8,16,32,64位形式的有符号和无符号的整数,这些整数遵循与C语言相似的命名规则.如8位无符号整数的类型为UInt8,32位有符号整数的类型为Int32,和Swift语言的其它类型一样,这些整型命名以大写字母开头. 整数的边界 你可以通过min或max属性为每一个整数类型指定一个最小值或最大值: 1 let 最小值 = UInt8.min // 最小值 等于 0,

Swift编程语言学习——注释、分号、整数、浮点数

注释 请将你的代码中的非执行文本注释成提示或者笔记以方便你将来阅读.Swift 的编译器将会在编译代码时自动忽略掉注释部分. Swift 中的注释与C 语言的注释非常相似.单行注释以双正斜杠作(//)为起始标记: // 这是一个注释 你也可以进行多行注释,其起始标记为单个正斜杠后跟随一个星号(/*),终止标记为一个星号后跟随单个正斜杠(*/): /* 这是一个, 多行注释 */ 与C 语言多行注释不同,Swift 的多行注释可以嵌套在其它的多行注释之中.你可以先生成一个多行注释块,然后在这个注释

泊学Swift系列之Swift Up and Running——变量和常量

Swift Up and Running——变量和常量 泊学原文 泊学技法视频 当我们学习一门语言的时候,无论是说还是写,也无论是外语或者编程语言,我们都会用自己已经掌握的语言中的元素去理解新语言中对应的部分.学习Swift也一样,作为一种编程语言,它有着和Objective-C,JavaScript或C#等其它编程语言共通的概念和类似的表达方式.如果你或多或少了解过一些编程语言,学习Swift将会是一个非常轻松的过程. Playground Playground是Apple在2014年WWDC

窥探Swift系列博客说明及其Swift版本间更新

Swift到目前为止仍在更新,每次更新都会推陈出新,一些Swift旧版本中的东西在新Swift中并不适用,而且新版本的Swift会添加新的功能.到目前为止,Swift为2.1版本.去年翻译的Swift书籍是1.0版本,所以上面一些东西并不在适用.虽然Swift语言仍在更新,但是其整体的基础框架已经形成,大的改动应该不会有,版本的更新更多的是语言新功能的添加和完善,所以并不用担心现在学的Swift会过时.更新也就是在原有的基础上去更新,所以学学Swift还是很有必要的.新的Swift版本中引入了好

[Swift系列]002-基础语法

基础语法就那老几样,很快可以说完 [常量.变量] 1.变量用 var,系统自动去判断类型,但变量再次赋值需保持数据类型一致 var  a=50 相信用过js/java/C#的,对这个var都不陌生 使用  var  变量名:数据类型  = 变量值 这种格式可以指定具体的数据类型,比如要指定float时 var  x:Float = 12.5 不这样写,直接var x=12.5,系统默认是double 2.常量用 let let pi=3.14 常量也可以使用绝对数据类型来定义: let x:Do

1.Swift教程翻译系列——关于Swift

英文版PDF下载地址http://download.csdn.net/detail/tsingheng/7480427 我本来是做JAVA的.可是有一颗折腾的心,苹果公布Swift以后就下载了苹果的开发文档.啃了几天.朦朦胧胧的看了个几乎相同,想静下心看能不能整个翻译出来.我英语一般般,仅仅是大致能看明确意思,非常多形容词不晓得该怎么说.希望众大神看到不合适的地方能指正.以下是第一篇,About Swift. 这篇最难翻译了. Swift是一种新的用于iOS和OS X应用开发的编程语言Swift

D&F学数据结构系列——红黑树

红黑树 定义:一棵二叉查找树如果满足下面的红黑性质,则为一棵红黑树: 1)每个结点不是红的就是黑的 2)根结点是黑的 3)每个叶结点是黑的 4)如果一个结点是红的,它的两个儿子都是黑的(即不可能有两个连续的红色结点) 5)对于每个结点,从该结点到其子孙结点的所有路径上包含相同数目的黑结点 性质: 这些约束确保了红黑树的关键特性: 从根到叶子的最长的可能路径不多于最短的可能路径的两倍长.结果是这个树大致上是平衡的.因为操作比如插入.删除和查找某个值的最坏情况时间都要求与树的高度成比例,这个在高度上

Welcome to Swift (苹果官方Swift文档初译与注解三十五)---248~253页(第五章-- 函数 完)

Function Types as Return Types (函数类型作为返回值类型) 一个函数的类型可以作为另一个函数的返回值类型.可以在一个函数的返回值箭头后面写上一个完整的函数类型. 例如: 下面的例子定义了两个简单的函数,分别为stepForward 和 stepBackward.其中stepForward函数返回值比它的输入值多1,stepBackward函数返回值比它输入值少1.这两个函数的 类型都是(Int) -> Int: func stepForward(input: Int

Welcome to Swift (苹果官方Swift文档初译与注解二十七)---189~198页(第四章-- 流程控制)

Switch 一个switch语句里包含一个值,并且用这个值与其他几个可能的匹配模式进行比较,然后根据成功匹配上的模式,执行相应的代码块.switch语句提供了比if语句更多的选项来相应多种潜 在的情况. 最简单的一个例子: switch some value to consider { case value 1:   respond to value 1 case value 2, value 3:   respond to value 2 or 3 default:   otherwise,