Generic Subscript

subscript(_:)

Accesses the contiguous subrange of the collection’s elements specified by a range expression.

Declaration

subscript<R>(r: R) -> Slice<Dictionary<Key, Value>> where R : RangeExpression, Self.Index == R.Bound { get }

Parameters

bounds

A range of the collection’s indices. The bounds of the range must be valid indices of the collection.

Discussion

The range expression is converted to a concrete subrange relative to this collection. For example, using a PartialRangeFrom range expression with an array accesses the subrange from the start of the range expression until the end of the array.

let streets = ["Adams", "Bryant", "Channing", "Douglas", "Evarts"]
let streetsSlice = streets[2...]
print(streetsSlice)
// ["Channing", "Douglas", "Evarts"]

The accessed slice uses the same indices for the same elements as the original collection uses. This example searches streetsSlice for one of the strings in the slice, and then uses that index in the original array.

let index = streetsSlice.firstIndex(of: "Evarts")    // 4
print(streets[index!])
// "Evarts"

Always use the slice’s startIndex property instead of assuming that its indices start at a particular value. Attempting to access an element by using an index outside the bounds of the slice’s indices may result in a runtime error, even if that index is valid for the original collection.

print(streetsSlice.startIndex)
// 2
print(streetsSlice[2])
// "Channing"

print(streetsSlice[0])
// error: Index out of bounds

Complexity: O(1)

See Also

Selecting Elements

subscript(Range<Dictionary<Key, Value>.Index>) -> Slice<Dictionary<Key, Value>>

Accesses a contiguous subrange of the collection’s elements.

func prefix(Int) -> Slice<Dictionary<Key, Value>>

Returns a subsequence, up to the specified maximum length, containing the initial elements of the collection.

func prefix(through: Dictionary<Key, Value>.Index) -> Slice<Dictionary<Key, Value>>

Returns a subsequence from the start of the collection through the specified position.

func prefix(upTo: Dictionary<Key, Value>.Index) -> Slice<Dictionary<Key, Value>>

Returns a subsequence from the start of the collection up to, but not including, the specified position.

func prefix(while: ((key: Key, value: Value)) -> Bool) -> Slice<Dictionary<Key, Value>>

Returns a subsequence containing the initial elements until predicate returns false and skipping the remaining elements.

func suffix(Int) -> Slice<Dictionary<Key, Value>>

Returns a subsequence, up to the given maximum length, containing the final elements of the collection.

func suffix(from: Dictionary<Key, Value>.Index) -> Slice<Dictionary<Key, Value>>

Returns a subsequence from the specified position to the end of the collection.