iOS开发Swift篇—(三)字符串和数据类型

一、字符串

字符串是String类型的数据,用双引号""包住文字内容 let website = "http://www.wendingding.com"

1.字符串的常见操作

(1)用加号 + 做字符串拼接

let scheme = "http://"

let path = “www.wendingding.com”

let website = scheme + path

// website的内容是”http://www.wendingding.com”

iOS开发Swift篇—(三)字符串和数据类型

(2)用反斜线 \ 和 小括号 () 做字符串插值(把常量\变量插入到字符串中)

let hand = 2

var age = 20

let str = "我今年\(age)岁了,有\(hand)只手"

// str的内容是"我今年20岁了,有2只手"

iOS开发Swift篇—(三)字符串和数据类型

注意:swift是类型安全语言,不同的数据类型是不能相加的。(需要强制转换类型)

iOS开发Swift篇—(三)字符串和数据类型

2.打印输出

Swift提供了2个打印输出函数

println :输出内容后会自动换行

print :对比println,少了个自动换行的功能

二、数据类型

1.Swift中常用的数据类型有

Int、Float、Double、Bool、Character、String

Array、Dictionary、元组类型(Tuple)、可选类型(Optional)

注意:数据类型的首字母都是大写的

2.指定变量\常量的数据类型

  在常量\变量名后面加上 冒号(:) 和 类型名称

let age: Int = 10

上面代码表示:定义了一个Int类型的常量age,初始值是10

提示:一般来说,没有必要明确指定变量\常量的类型。如果在声明常量\变量时赋了初始值,Swift可以自动推断出这个常量\变量的类型

如:let age = 20 Swift会推断出age是Int类型,因为20是个整数

iOS开发Swift篇—(三)字符串和数据类型

三、变量的初始化

Swift严格要求变量在使用之前必须进行初始化

注意:下面的代码是错误的

var a: Int

let c = a + 10

说明:

第1行代码中:Swift并不会为变量a赋初值,a没有初始化

第2行代码会报错

下面的代码是正确的

var a: Int = 20

let c = a + 10

四、整数

1.整数的分类

整数分为2种类型

有符号(signed):正、负、零

无符号(unsigned):正、零

Swift提供了8、16、32、64位的有符号和无符号整数,比如

UInt8 :8位无符号整型

Int32 :32位有符号整型

Int8、Int16、Int32、Int64、UInt8、UInt16、UInt32、UInt64

2.最值

可以通过min和max属性来获取某个类型的最小值和最大值

let minValue = UInt8.min // UInt8 类型的 min 等于0

let maxValue = UInt8.max // UInt8 类型的 max 等于255

3.Int和UInt

Swift还提供了特殊的有符号整数类型Int和无符号整数类型UInt

说明:Int\UInt的长度和当前系统平台一样

在32位系统平台上,Int和UInt的长度是32位

在64位系统平台上,Int和UInt的长度是64位

Int在32位系统平台的取值范围:-2147483648 ~ 2147483647

建议

在定义变量时,别总是在考虑有无符号、数据长度的问题

尽量使用Int,这样可以保证代码的简洁、可复用性

4.存储范围

每种数据类型都有各自的存储范围,比如

Int8的存储范围是:–128 ~ 127

UInt8的存储范围是:0 ~ 255

如果数值超过了存储范围,编译器会直接报错

注意:下面的语句都会直接报错

let num1: UInt8 = -1

let num2: Int8 = Int8.max + 1

说明:

第1行代码报错原因: UInt8不能存储负数

第2行代码报错原因: Int8能存储的最大值是Int8.max

5.整数的表示形式

整数的4种表示形式

(1)十进制数:没有前缀

  let i1 = 10 // 10

(2)二进制数:以0b为前缀

  let i2 = 0b1010 // 10

(3)八进制数:以0o为前缀

  let i3 = 0o12 // 10

(4)十六进制数:以0x为前缀

  let i4 = 0xA // 10

五、浮点数

1.浮点数说明

浮点数,就是小数。Swift提供了两种浮点数类型

Double :64位浮点数,当浮点值非常大或需要非常精确时使用此类型

Float :32位浮点数,当浮点值不需要使用Double的时候使用此类型

精确程度

Double :至少15位小数

Float :至少6位小数

注意:如果没有明确说明类型,浮点数默认就是Double类型

let num = 0.14 // num是Double类型的常量

2.浮点数的表示形式

浮点数可以用 十进制十六进制 2种进制来表示

(1)十进制(没有前缀)

1)没有指数:let d1 = 12.5

2)有指数 :let d2 = 0.125e2

// 0.125e2 == 0.125 * 10²

MeN == M * 10的N次方

(2)十六进制(以0x为前缀,且一定要有指数)

let d3 = 0xC.8p0

// 0xC.8p0 == 0xC.8 * 2º == 12.5 * 1

0xMpN == 0xM * 2的N次方

let d3 = 0xC.8p1

// 0xC.8p1 == 0xC.8 * 2¹ == 12.5 * 2 == 25.0

3.数字格式

数字可以增加额外的格式,使它们更容易阅读

(1)可以增加额外的零 0

let money = 001999 // 1999

let money2 = 001999.000 // 1999.0

(2)可以增加额外的下划线 _ ,以增强可读性

let oneMillion1 = 1_000_000 // 1000000

let oneMillion2 = 100_0000 // 1000000

let overOneMillion = 1_000_000.000_001 // 1000000.000001

说明:增加了额外的零 0和下划线 _ ,并不会影响原来的数值大小

六、类型转换

两个类型不相同的数值,是不能直接进行运算的

示例1:

注意:下面的语句是错误的

let num1: UInt8 = 10;

let num2: Int = 20;

let sum: Int = num1 + num2

第3行会报错说明:

报错原因:num1是UInt8类型,num2是类型Int,类型不同,不能相加

解决方案:将num1转为Int类型,就能与num2进行相加

下面的语句是正确的

let sum: Int = Int(num1) + num2

示例2:

注意:下面的语句是错误的

let num1 = 3 // num1是Int类型

let num2 = 0.14 // num2是Double类型

let sum = num1 + num2

第3行报错说明:

报错原因:num1是Int类型,num2是类型Double,类型不同,不能相加

解决方案:将num1转为Double类型,就能与num2进行相加

下面的语句是正确的

let sum = Double(num1) + num2

注意:

下面的写法是正确的

let sum = 3 + 0.14

3和0.14相加得到结果3.14,等赋值以后,编译器才会自动推断出sum是Double类型

七、类型别名

可以使用typealias关键字定义类型的别名,跟C语言的typedef作用类似

  typealias MyInt = Int // 给Int类型起了个别名叫做MyInt

原类型名称能用在什么地方,别名就能用在什么地方

  声明变量\常量类型

  let num: MyInt = 20

获得类型的最值

  let minValue = MyInt.min

类型转换

  let num = MyInt(3.14) // 3

上一篇:Paper:《A Unified Approach to Interpreting Model Predictions》论文解读与翻译


下一篇:Android——使用LruCache缓存图片