digitToInt所在位置是kotlin.text.digitToInt,其相关用法介绍如下。

用法一

fun Char.digitToInt(): Int

返回此 Char 表示的十进制数字的数值。如果此 Char 不是有效的十进制数字,则引发异常。

如果 Char 的 isDigit 为真,则认为 Char 表示十进制数字。在这种情况下,将返回字符的 Unicode 十进制数字值。

例子:

import java.util.*
import kotlin.test.*

fun main(args: Array<String>) {
//sampleStart
println('5'.digitToInt()) // 5
println('3'.digitToInt(radix = 8)) // 3
println('A'.digitToInt(radix = 16)) // 10
println('k'.digitToInt(radix = 36)) // 20

// radix argument should be in 2..36
// '0'.digitToInt(radix = 1) //  will fail
// '1'.digitToInt(radix = 100) //  will fail
// only 0 and 1 digits are valid for binary numbers
// '5'.digitToInt(radix = 2) //  will fail
// radix = 10 is used by default
// 'A'.digitToInt() //  will fail
// symbol '+' is not a digit in any radix
// '+'.digitToInt() //  will fail
// Only Latin letters are valid for digits greater than 9.
// 'β'.digitToInt(radix = 36) //  will fail
//sampleEnd
}

输出:

5
3
10
20

用法二

fun Char.digitToInt(radix: Int): Int

返回此 Char 在指定 radix 中表示的数字的数值。如果 radix 不在 2..36 范围内,或者此 Char 不是指定 radix 中的有效数字,则引发异常。

如果以下至少一项为真,则认为 Char 表示指定 radix 中的数字:

  • isDigit 是 Char 的 true 并且字符的 Unicode 十进制数字值小于指定的 radix 。在这种情况下,返回十进制数字值。
  • Char 是大写拉丁字母 'A' 到 'Z' 之一,其 code 小于 radix + 'A'.code - 10 。在这种情况下,返回this.code - 'A'.code + 10
  • Char 是小写拉丁字母 'a' 到 'z' 之一,其 code 小于 radix + 'a'.code - 10 。在这种情况下,返回this.code - 'a'.code + 10
  • Char 是全角拉丁大写字母 '\uFF21' 到 '\uFF3A' 之一,其 code 小于 radix + 0xFF21 - 10 。在这种情况下,返回this.code - 0xFF21 + 10
  • Char 是全角拉丁小写字母 '\uFF41' 到 '\uFF5A' 之一,其 code 小于 radix + 0xFF41 - 10 。在这种情况下,返回this.code - 0xFF41 + 10

例子:

import java.util.*
import kotlin.test.*

fun main(args: Array<String>) {
//sampleStart
println('5'.digitToInt()) // 5
println('3'.digitToInt(radix = 8)) // 3
println('A'.digitToInt(radix = 16)) // 10
println('k'.digitToInt(radix = 36)) // 20

// radix argument should be in 2..36
// '0'.digitToInt(radix = 1) //  will fail
// '1'.digitToInt(radix = 100) //  will fail
// only 0 and 1 digits are valid for binary numbers
// '5'.digitToInt(radix = 2) //  will fail
// radix = 10 is used by default
// 'A'.digitToInt() //  will fail
// symbol '+' is not a digit in any radix
// '+'.digitToInt() //  will fail
// Only Latin letters are valid for digits greater than 9.
// 'β'.digitToInt(radix = 36) //  will fail
//sampleEnd
}

输出:

5
3
10
20