Відповіді:
Ви можете об'єднати масиви +, створивши новий масив
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]
AnyObjectвказує на об'єкт, який, як я розумію, означає щось, що інстанціюється від типу класу. CGFloatне є об’єктом, це скалярне значення. Як я розумію, масиви можуть містити скаляри, якщо тільки вони не визначені як містять AnyObjectабо додатково уточнені. Однак я підозрюю, що проблема полягає в тому, що масив загорнуто в необов'язковий, тому вам доведеться розгортати його !або ?спочатку
bчастина aмодифікуються (тому , можливо , eliding копії bпід час a.appendContentsOf(b))?
З Swift 5, відповідно до ваших потреб, ви можете обрати один із шести наступних способів об'єднання / об'єднання двох масивів.
Array's+(_:_:)Arrayмає +(_:_:)загальний оператор. +(_:_:)має таку заяву :
Створює нову колекцію шляхом об'єднання елементів колекції та послідовності.
static func + <Other>(lhs: Array<Element>, rhs: Other) -> Array<Element> where Other : Sequence, Self.Element == Other.Element
Наведений нижче зразок коду дитячої площадки показує, як об’єднати два масиви типу [Int]в новий масив за допомогою +(_:_:)загального оператора:
let array1 = [1, 2, 3]
let array2 = [4, 5, 6]
let flattenArray = array1 + array2
print(flattenArray) // prints [1, 2, 3, 4, 5, 6]
Array's +=(_:_:)genericArrayмає +=(_:_:)загальний оператор. +=(_:_:)має таку заяву :
Додає елементи послідовності до колекції, що змінюється діапазоном.
static func += <Other>(lhs: inout Array<Element>, rhs: Other) where Other : Sequence, Self.Element == Other.Element
Наведений нижче зразок коду Playground показує, як додати елементи масиву типу [Int]до існуючого масиву за допомогою +=(_:_:)загального оператора:
var array1 = [1, 2, 3]
let array2 = [4, 5, 6]
array1 += array2
print(array1) // prints [1, 2, 3, 4, 5, 6]
Arraysappend(contentsOf:)У Свіфта Arrayє append(contentsOf:)метод. append(contentsOf:)має таку заяву :
Додає елементи послідовності чи колекції до кінця цієї колекції.
mutating func append<S>(contentsOf newElements: S) where S : Sequence, Self.Element == S.Element
Наведений нижче зразок коду дитячої площадки показує, як додати масив до іншого типу масиву за [Int]допомогою append(contentsOf:)методу:
var array1 = [1, 2, 3]
let array2 = [4, 5, 6]
array1.append(contentsOf: array2)
print(array1) // prints [1, 2, 3, 4, 5, 6]
SequencesflatMap(_:)Swift пропонує flatMap(_:)метод для всіх типів, які відповідають Sequenceпротоколу (включаючи Array). flatMap(_:)має таку заяву :
Повертає масив, що містить зв'язані результати виклику даної трансформації з кожним елементом цієї послідовності.
func flatMap<SegmentOfResult>(_ transform: (Self.Element) throws -> SegmentOfResult) rethrows -> [SegmentOfResult.Element] where SegmentOfResult : Sequence
Наступний зразок коду дитячої площадки показує, як об’єднати два масиви типу [Int]в новий масив за допомогою flatMap(_:)методу:
let array1 = [1, 2, 3]
let array2 = [4, 5, 6]
let flattenArray = [array1, array2].flatMap({ (element: [Int]) -> [Int] in
return element
})
print(flattenArray) // prints [1, 2, 3, 4, 5, 6]
Sequence«S joined()методом і Array» s init(_:)ініціалізаторSwift пропонує joined()метод для всіх типів, які відповідають Sequenceпротоколу (включаючи Array). joined()має таку заяву :
Повертає елементи цієї послідовності послідовних послідовностей.
func joined() -> FlattenSequence<Self>
Крім того, у Swift Arrayє init(_:)ініціалізатор. init(_:)має таку заяву :
Створює масив, що містить елементи послідовності.
init<S>(_ s: S) where Element == S.Element, S : Sequence
Тому наступний зразок коду Playground показує, як об’єднати два масиви типу [Int]в новий масив, використовуючи joined()метод та init(_:)ініціалізатор:
let array1 = [1, 2, 3]
let array2 = [4, 5, 6]
let flattenCollection = [array1, array2].joined() // type: FlattenBidirectionalCollection<[Array<Int>]>
let flattenArray = Array(flattenCollection)
print(flattenArray) // prints [1, 2, 3, 4, 5, 6]
Arraysreduce(_:_:)У Свіфта Arrayє reduce(_:_:)метод. reduce(_:_:)має таку заяву :
Повертає результат поєднання елементів послідовності за допомогою заданого замикання.
func reduce<Result>(_ initialResult: Result, _ nextPartialResult: (Result, Element) throws -> Result) rethrows -> Result
Наведений нижче код майданчика показує, як об’єднати два масиви типу [Int]в новий масив за допомогою reduce(_:_:)методу:
let array1 = [1, 2, 3]
let array2 = [4, 5, 6]
let flattenArray = [array1, array2].reduce([], { (result: [Int], element: [Int]) -> [Int] in
return result + element
})
print(flattenArray) // prints [1, 2, 3, 4, 5, 6]
+для 2 масивів і joined()для масиву масивів.
+оператора, це генерує абсолютно божевільні рази компіляції.
Якщо ви не великий прихильник перевантаження оператора, або просто більше функціонального типу:
// 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()
Це повернеться, FlattenBidirectionalCollectionтому, якщо ви просто хочете, CollectionTypeцього буде достатньо, і у вас буде ледача оцінка безкоштовно. Якщо вам точно потрібен масив, ви можете зробити це:
let c = Array([a, b].flatten())
Щоб заповнити список можливих альтернатив, reduceможна використовувати для реалізації поведінки згладжування :
var a = ["a", "b", "c"]
var b = ["d", "e", "f"]
let res = [a, b].reduce([],combine:+)
Найкраща альтернатива (продуктивна / пам'ятна) серед представлених - це просто те flatten, що просто ліниво обернути початкові масиви, не створюючи нової структури масиву.
Але зауважте, що flatten не повертає a LazyCollection, так що лінива поведінка не буде поширюватися на наступну операцію по ланцюгу (карта, flatMap, фільтр тощо).
Якщо ленивости мають сенс у вашому конкретному випадку, тільки НЕ забудьте додати препенд або .lazyдо flatten(), наприклад, зміна Tomasz Sample наступним чином:
let c = [a, b].lazy.flatten()
Swift 3.0
Ви можете створити новий масив, додавши два існуючих масиви сумісних типів з оператором додавання ( +). Тип нового масиву виводиться з типу двох масивів, які ви додаєте разом,
let arr0 = Array(repeating: 1, count: 3) // [1, 1, 1]
let arr1 = Array(repeating: 2, count: 6)//[2, 2, 2, 2, 2, 2]
let arr2 = arr0 + arr1 //[1, 1, 1, 2, 2, 2, 2, 2, 2]
це правильні результати наведених вище кодів.
var arrayOne = [1,2,3]
var arrayTwo = [4,5,6]
якщо потрібно результат як: [1,2,3, [4,5,6]]
arrayOne.append(arrayTwo)
наведений вище код перетворить arrayOne в єдиний елемент і додасть його в кінець arrayTwo.
якщо ви хочете отримати результат як: [1, 2, 3, 4, 5, 6],
arrayOne.append(contentsOf: arrayTwo)
вищевказаний код додасть усі елементи arrayOne в кінці масивуTwo.
Дякую.
Аналогічно, зі словниками масивів можна:
var dict1 = [String:[Int]]()
var dict2 = [String:[Int]]()
dict1["key"] = [1,2,3]
dict2["key"] = [4,5,6]
dict1["key"] = dict1["key"]! + dict2["key"]!
print(dict1["key"]!)
і ви можете повторити dict1 і додати dict2, якщо "ключ" відповідає
Масив марджів, які є різними типами даних:
var arrayInt = [Int]()
arrayInt.append(6)
var testArray = ["a",true,3,"b"] as [Any]
testArray.append(someInt)
Вихід:
["a", true, 3, "b", "hi", 3, [6]]