官术网_书友最值得收藏!

Ranges

A range is defined as an interval that has a start value and an end value. Any types which are comparable can be used to create a range, which is done using the .. operator:

    val aToZ = "a".."z" 
    val oneToNine = 1..9 

Once a range is created, the in operator can be used to test whether a given value is included in the range. This is why the types must be comparable. For a value to be included in a range, it must be greater than or equal to the start value and less than or equal to the end value:

    val aToZ = "a".."z" 
    val isTrue = "c" in aToZ 
  
    val oneToNine = 1..9 
    val isFalse = 11 in oneToNine 

Integer ranges such as (ints, longs, and chars) also have the ability to be used in a for loop. See the Loops section for further details.

There are further library functions to create ranges not covered by the .. operator; for example, downTo() will create a range counting down, and rangeTo()will create a range up to a value. Both of these functions are defined as extension functions on numerical types:

    val countingDown = 100.downTo(0) 
    val rangeTo = 10.rangeTo(20) 

Once a range is created, you can modify the range, returning a new range. To modify the delta between each successive term in the range, we can use the step() function:

    val oneToFifty = 1..50 
    val oddNumbers = oneToFifty.step(2) 

You cannot use a negative value here to create a decreasing range. Finally, ranges can be reversed using the reversed() function. As the name implies, it returns a new range with the start and end values switched, and the step value negated:

    val countingDownEvenNumbers = (2..100).step(2).reversed() 
主站蜘蛛池模板: 娄烦县| 崇州市| 西和县| 江山市| 静海县| 古丈县| 正定县| 营口市| 仪陇县| 高要市| 福泉市| 常山县| 望都县| 武冈市| 石台县| 通城县| 崇左市| 金沙县| 凭祥市| 漳平市| 会昌县| 双江| 巫溪县| 武鸣县| 涞源县| 云浮市| 曲阜市| 汶川县| 永兴县| 芷江| 阜平县| 怀安县| 佛教| 高雄市| 合川市| 平定县| 柘荣县| 中方县| 阜新市| 安西县| 正蓝旗|