Hacker News new | past | comments | ask | show | jobs | submit login

One thing to look out for is that Swift Arrays aren’t really arrays. https://www.raywenderlich.com/1172-collection-data-structure...:

”1. Accessing any value at a particular index in an array is at worst O(log n), but should usually be O(1).

2. Searching for an object at an unknown index is at worst O(n (log n)), but will generally be O(n).

3. Inserting or deleting an object is at worst O(n (log n)) but will often be O(1). These guarantees subtly deviate from the simple “ideal” array that you might expect from a computer science textbook or the C language, where an array is always a sequence of items laid out contiguously in memory”

If you want a more traditional data structure, use ContiguousArray, which is an array. https://developer.apple.com/documentation/swift/contiguousar...:

”The ContiguousArray type is a specialized array that always stores its elements in a contiguous region of memory. This contrasts with Array, which can store its elements in either a contiguous region of memory or an NSArray instance if its Element type is a class or @objc protocol”




My instinct is to find this horrifying. Is there a good reason for this?

If I have an array of ints, is it contiguous?

Especially with modern computers and how importance data locality is the name "array" is kind of sacred. If you want a fancy weird-non array give THAT the longer, annoying name.


Presumably Objective-C/Cocoa compatibility. Although I'm wouldn't be able to tell you why that would require non-contiguous storage... surely @NSArray is contiguous?



"If the array’s Element type is a struct or enumeration, Array and ContiguousArray should have similar efficiency."




Guidelines | FAQ | Lists | API | Security | Legal | Apply to YC | Contact

Search: