Go Keyword range: Difference between revisions
Line 2: | Line 2: | ||
* [[Go_Language#range_keyword|Go Language]] | * [[Go_Language#range_keyword|Go Language]] | ||
=Overview= | =Overview= | ||
<code>range</code> can be used to iterated through [[Go_Channels#Iteratively_Reading_from_a_Channel|channels]]. | |||
=Iterating through Arrays= | =Iterating through Arrays= | ||
{{Internal|Go_Arrays#Iterating_though_Arrays|Iterating though Arrays}} | {{Internal|Go_Arrays#Iterating_though_Arrays|Iterating though Arrays}} |
Revision as of 17:49, 5 September 2023
Internal
Overview
range
can be used to iterated through channels.
Iterating through Arrays
Iterating through Slices
Iterating over Map Keys and Values
TO PROCESS
Internal
Overview
range keyword is used to iterate over strings, arrays, slices, maps, channels and variadic function arguments. It returns two values. On the first position is the index/key, and on the second position is the copy of the value in that element. For slices and arrays, range always starts to iterate from index 0. If you need more control over the start index, use a for loop.
- Note 1: that only a first identifier is declared, that is the index and not the value, as the intuition would suggest. See examples below.
- Note 2: range returns a copy of the value, in the same way it would pass an argument to a function. It does NOT return a reference to the element in the structure it iterates over.
Iterating over Key/Values in a Map
m := map[string]string { "k1": "v1", "k2": "v2", "k3": "v3", } for key, value := range m { // }
range and Channels
range can be used to receive from a channel in a for loop. range blocks until a value is available on the channel. The iteration values produced are the successive values sent on the channel until the channel is closed and all values are consumed. When the channel is closed, the for loop exists:
var c chan string for m := range c { // do something with the message }
If the channel is nil, the range expression blocks forever.