Swift 集合类型

 Swift语言提供数组和字典的集合类型

 

 Swift 语言里的数组和字典中存储的数据值类型必须明确 ,即数组中只能存放同类型的数据。

1: 数组 

数组的创建

var shoppingList: String[] = ["tset", "hell", “hell”]
var arrayInt:Int[] = [1, 3]

var arrayIntEx  = [55, 32]//使用推理类型

//空数组的创建

 var someInts = Int[]()
 println("\(someInts.isEmpty)")
//创建指定类型(Double)和个数(3)并设置初始值(0.0)
 var threeDoubles = Double[](count: 3, repeatedValue:0.0) 

数组的访问用下标访问。下标从0开始,注意不要越界了。

var arrayIntEx  = [1, 3]
arrayIntEx[1] = 99
println("\(arrayIntEx[1])")

数组的可修改性是依赖var或者let控制的

数组元素个数使用 count ,isEmpty检测是否位空数组

var arrayIntEx  = [1, 3]
let count = arrayIntEx.count
let bFlag = shoppingList.isEmpty
println("\(count)\n\(bFlag)")

数组元素追加  append 。必须是var类型数组,而且追加的元素类型要和数组类型一致。同时也可以用 += 操作

var arrayIntEx  = [1, 3]
arrayIntEx.append(8)
arrayIntEx += 9
arrayIntEx += [55, 66]
println("\(arrayIntEx[2])\n\(arrayIntEx[3])\n\(arrayIntEx[4])\n\(arrayIntEx[5])\n")

数组元素指定索引号插入 insert().insert在指定索引号的时候,最大为原有元素个数+现插入的元素个数-1,这样类似于在末尾添加。insert插入后,原有的元素后移动。

var arrayIntEx  = [1, 3]
arrayIntEx.insert(5, atIndex:2)
println("\(arrayIntEx)")

数组指定索引号删除 removeAtIndex

var arrayIntEx  = [1, 3, 9]
arrayIntEx.removeAtIndex(1)
println("\(arrayIntEx)")

 

数组遍历用 for in 

var arrayIntEx  = [1, 3, 9]
for item in arrayIntEx {
    println("\(item)")
}

如果要使用索引号和值,那用enumerate 

var arrayTest = ["ax", "bx", "sx", "sxx"]
for (index, value) in enumerate(arrayTest)
 {  println("Item: \(index + 1): \(value)") 
}

 数组拼接 如果两个数组类型一样,可以用+做拼接。当然结果的顺序和你拼接的时候的顺序时一致的

var arrayIntFirst = [2, 5]
var  arrayIntSecond = [6, 77]
var arrayRes =  arrayIntSecond +  arrayIntFirst
println("\(arrayRes)")

 

2:字典

Swift 的字典使用时需要具体规定可以存储键和值类型 ,字典存储时没有顺序的,它依赖于一个可以哈希的keyValue值来查找。估计它是把keyValue哈希后作为key建立的红黑二茬树来查找的。

字典使用 Dictionary<KeyType, ValueType>定义 .KeyType要求可以哈希的,ValueType在一个字典里类型必须一致

字典创建

var airports: Dictionary<Int, String> = [1: "yamide",2: "soga"]//显示类型说明
var dicDefault = [2:"xx", 33:"oo"]//使用了类型推理,这里比较特殊的是 2和3 不能用 2.0 和 3 ,它不支持类型的转换推理的
var namesOfIntegers = Dictionary<Int, String>()//空数组的创建
var dicEmpty = [:]

字典的可否修改时依靠var和let控制的

字典元素个数使用count 属性可以得到

var dicDefault = [2:"xx", 33:"oo"]
println("\(dicDefault.count)")

字典元素的更新。可以用下标关键字添加

var dicDefault = [2:"xx", 33:"oo"]
dicDefault[22] = "tt"
println("\(dicDefault)")

如果下标添加的key是字典里已经有的,那么它会update数据.

updateValue(forKey:)方法可以设置或者更新特定键对应的值 .如果keyValue没有就添加,字典中已经有则更新

 

var dicDefault = [1:"xx", 2:"oo"]
dicDefault[3] = "tt"
dicDefault.updateValue("sx", forKey:4)//add
dicDefault.updateValue("sbcd", forKey:2)//update

删除  removeValueForKey 

var dicDefault = [1:"xx", 2:"oo"]
dicDefault[3] = "tt"
dicDefault.updateValue("sx", forKey:4)
dicDefault.removeValueForKey(2)
println("\(dicDefault)")

字典遍历 可以使用for in 遍历字典键值对。以元组形式返回

var dicDefault = [1:"xx", 2:"oo"]
for(key, value)in dicDefault {
    println("key:\(key) value:\(value)\n")
}

字典可以用 values 返回所有值 keys返回所有关键字

var dicDefault = [1:"xx", 2:"oo"]
var keys = dicDefault.keys
var values = dicDefault.values
for key in keys {
    println("key:\(key)\n")
}
for value in values {
    println("value:\(value)\n")
}

 

 

posted @ 2014-07-24 18:33  酱酱爱  阅读(583)  评论(0编辑  收藏  举报