如果在swift中创建了两个数组,就像这样:

var a:[CGFloat] = [1, 2, 3]
var b:[CGFloat] = [4, 5, 6]

如何将它们合并为[1,2,3,4,5,6]?


当前回答

如果你正在处理大型序列,那么更有效的方法是使用Apple算法包中定义的链方法。

let n1 = [1, 2, 3]
let n2 = [4, 5, 6]

let allNumbers = chain(n1, n2)
for num in allNumbers {
    print(num) // for loop prints 1 to 6
}

// Similarly for String type
let s = chain("foo", "BAR") // produces "fooBAR"

Chain相对于其他方法的优点:

允许混合不同的序列类型

let n = chain([10, 20, 30], 1...3) // will produce 10, 20, 30, 1, 2, 3

不进行新的内存分配

chain方法本质上迭代第一个序列,当它在第一个序列中遇到endIndex时,它就开始无缝地迭代第二个序列。

其他回答

您可以用+连接数组,构建一个新数组

let c = a + b
print(c) // [1.0, 2.0, 3.0, 4.0, 5.0, 6.0]

或者用+=将一个数组附加到另一个数组(或append):

a += b

// Or:
a.append(contentsOf: b)  // Swift 3
a.appendContentsOf(b)    // Swift 2
a.extend(b)              // Swift 1.2

print(a) // [1.0, 2.0, 3.0, 4.0, 5.0, 6.0]

如果你正在处理大型序列,那么更有效的方法是使用Apple算法包中定义的链方法。

let n1 = [1, 2, 3]
let n2 = [4, 5, 6]

let allNumbers = chain(n1, n2)
for num in allNumbers {
    print(num) // for loop prints 1 to 6
}

// Similarly for String type
let s = chain("foo", "BAR") // produces "fooBAR"

Chain相对于其他方法的优点:

允许混合不同的序列类型

let n = chain([10, 20, 30], 1...3) // will produce 10, 20, 30, 1, 2, 3

不进行新的内存分配

chain方法本质上迭代第一个序列,当它在第一个序列中遇到endIndex时,它就开始无缝地迭代第二个序列。

如果你不喜欢操作符重载,或者更喜欢函数类型:

// use flatMap
let result = [
    ["merge", "me"], 
    ["We", "shall", "unite"],
    ["magic"]
].flatMap { $0 }
// Output: ["merge", "me", "We", "shall", "unite", "magic"]

// ... or reduce
[[1],[2],[3]].reduce([], +)
// Output: [1, 2, 3]

自Swift 2.0以来,我最喜欢的方法是扁平化

var a:[CGFloat] = [1, 2, 3]
var b:[CGFloat] = [4, 5, 6]

let c = [a, b].flatten()

这将返回flatbidirectionalcollection,所以如果你只是想要一个CollectionType,这就足够了,你将有免费的懒惰求值。如果你确实需要数组,你可以这样做:

let c = Array([a, b].flatten())

Swift 5阵列扩展

extension Array where Element: Sequence {
    func joined() -> Array<Element.Element> {
        return self.reduce([], +)
    }
}

例子:

let array = [[1,2,3], [4,5,6], [7,8,9]]
print(array.joined())

//result: [1, 2, 3, 4, 5, 6, 7, 8, 9]