如何在Kotlin中正确处理大于127的字节值?

时间:2016-07-29 05:37:24

标签: types type-conversion kotlin

想象一下,我有一个Kotlin程序,其变量b的类型为Byte,外部系统会在其中写入大于127的值。 “外部”意味着我无法更改它返回的值的类型。

val a:Int = 128 val b:Byte = a.toByte()

a.toByte()b.toInt()都返回-128

想象一下,我想从变量128中获取正确的值(b)。我该怎么办?

换句话说:magicallyExtractRightValue的哪些实现会使以下测试运行?

@Test
fun testByteConversion() {
    val a:Int = 128
    val b:Byte = a.toByte()

    System.out.println(a.toByte())
    System.out.println(b.toInt())

    val c:Int = magicallyExtractRightValue(b)

    Assertions.assertThat(c).isEqualTo(128)
}

private fun magicallyExtractRightValue(b: Byte): Int {
    throw UnsupportedOperationException("not implemented")
}

更新1: Thilo建议的此解决方案似乎有效。

private fun magicallyExtractRightValue(o: Byte): Int = when {
    (o.toInt() < 0) -> 255 + o.toInt() + 1
    else -> o.toInt()
}

2 个答案:

答案 0 :(得分:21)

使用Kotlin 1.3+,您可以使用unsigned types。例如toUByteKotlin Playground):

private fun magicallyExtractRightValue(b: Byte): Int {
    return b.toUByte().toInt()
}

甚至要求直接使用UByte代替ByteKotlin Playground):

private fun magicallyExtractRightValue(b: UByte): Int {
    return b.toInt()
}

对于Kotlin 1.3之前的版本,我建议使用extension function创建and来执行此操作:

fun Byte.toPositiveInt() = toInt() and 0xFF

使用示例:

val a: List<Int> = listOf(0, 1, 63, 127, 128, 244, 255)
println("from ints: $a")
val b: List<Byte> = a.map(Int::toByte)
println("to bytes: $b")
val c: List<Int> = b.map(Byte::toPositiveInt)
println("to positive ints: $c")

示例输出:

from ints: [0, 1, 63, 127, 128, 244, 255]
to bytes: [0, 1, 63, 127, -128, -12, -1]
to positive ints: [0, 1, 63, 127, 128, 244, 255]

答案 1 :(得分:1)

好的printf可以满足我们的要求:

java.lang.String.format("%02x", byte)