Swift 集合类型

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

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

1: 数组

数组的创建

var shoppingList: String[] = ["tset", "hell", “hell”]
var arrayInt:Int[] = [, ] 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  = [, ]
arrayIntEx[] =
println("\(arrayIntEx[1])")

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

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

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

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

var arrayIntEx  = [, ]
arrayIntEx.append()
arrayIntEx +=
arrayIntEx += [, ]
println("\(arrayIntEx[2])\n\(arrayIntEx[3])\n\(arrayIntEx[4])\n\(arrayIntEx[5])\n")

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

var arrayIntEx  = [, ]
arrayIntEx.insert(, atIndex:)
println("\(arrayIntEx)")

数组指定索引号删除 removeAtIndex

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

数组遍历用 for in

var arrayIntEx  = [, , ]
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 = [, ]
var arrayIntSecond = [, ]
var arrayRes = arrayIntSecond + arrayIntFirst
println("\(arrayRes)")

2:字典

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

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

字典创建

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

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

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

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

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

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

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

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

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

删除  removeValueForKey

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

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

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

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

var dicDefault = [:"xx", :"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")
}
上一篇:django自定义分页器


下一篇:一个可以控制提示框显示为top,bottom,left,right的小方法