数组

数组的值意义

  1. Swift 数组具有值语义,它们从不会在不同的地方被共享使用(没有 共用的引用)


    不共享内存

    类型推断
  2. 两个都改变


    类型限定并不能保证
  3. 不影响原数组


    不影响原数组
  4. 为什么a用let修饰可以改变,c却不可以(swift中只有一种类型Array),用var和let修饰可变


    疑惑

数组变形

  1. map:每个值执行转换操作
  2. 使用函数将行为参数化
  3. 一些函数
    → map和 atMap—如何对元素进行变换
    → lter—元素是否应该被包含在结果中
    → reduce—如何将元素合并到一个总和的值中
    → sort和lexicographicCompare—两个元素应该以怎样的顺序进行排列 → indexOf和contains—元素是否符合某个条件
    → minElement和maxElement—两个元素中的最小/最大值是哪个
    → elementsEqual和startsWith—两个元素是否相等
    → split—这个元素是否是一个分割符
    → accumulate—累加,和reduce类似,不过是将所有元素合并到一个数组中,而且保 留合并时每一步的值。
    → allMatch和noneMatch—测试序列中是不是所有元素都满足某个标准,以及是不是 没有任何元素满足某个标准。它们可以通过 contains 和它进行了精心对应的否定形式 来构建。
    → count — 计算满足条件的元素的个数,和 lter 相似,但是不会构建数组。
    → indicesOf—返回一个包含满足某个标准的所有元素的索引的列表,和indexOf类似, 但是不会在遇到首个元素时就停止。
    → takeWhile—当判断为真的时候,将元素滤出到结果中。一旦不为真,就将剩余的抛 弃。和 lter 类似,但是会提前退出。这个函数在处理无限序列或者是延迟计算 (lazily-computed) 的序列时会非常有用。
    → dropWhile—当判断为真的时候,丢弃元素。一旦不为真,返回将其余的元素。和 takeWhile 类似,不过返回相反的集合。
  4. 找特定元素的扩展 ,配合guard使用
extension Sequence {
    func  ndElement (match: (Iterator.Element)->Bool) -> Iterator.Element? {
        for element in self where match(element) { return element
        }
        return nil
    }
}```
5.   有意思的累加

extension Array {
func accumulate<U>(initial: U, combine: (U, Element) -> U) -> [U] {
var running = initial
return self.map { next in
running = combine(running, next)
return running }
} } ```

  1. Filter过滤所有结果,Swift 内建的用来代表参数的简写 $0
    fbs. flter { num in num%2==0}简化代码可以写成这样 fbs. flter { $0%2==0}
    实现
func  lter (includeElement: Element -> Bool) -> [Element] {
var result: [Element] = []
for x in self where includeElement(x) {
result . append(x) }
return result }
}```

extension SequenceType {
public func allMatch(predicate: Generator.Element -> Bool) -> Bool {
// 对于一个条件,如果没有元素不满足它的话,那意味着所有元素都满足它:
return !self.contains { !predicate($0) } }
}```

  1. reduce操作

extension Array {
func reduce<U>(initial: U, combine: (U, Element) -> U) -> U {
var result = initial; for e in self {result = combine(result,e)
}
return result
}
}
c.reduce(initial: 0) { (totoal, p) -> Int in
totoal + p
}

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容