从Long到ByteArray的两次转换有什么区别?

时间:2017-02-02 11:43:13

标签: kotlin

import java.lang.Long as JLong
import java.lang.Byte as JByte
import java.nio.ByteBuffer

fun Long.toByteArray1() = 
    ByteBuffer.allocate(JLong.SIZE / JByte.SIZE)
        .putLong(this)
        .array()

fun Long.toByteArray2() =
    this.toString()
        .toByteArray(Charsets.UTF_8)

fun main(args: Array<String>) {
    val a1: ByteArray = 10L.toByteArray1()
    val a2: ByteArray = 10L.toByteArray2()
    println("a1 = ${a1.toString()}")
    println("a1 = ${ByteBuffer.wrap(a1).getLong()}")
    println("a2 = ${a2.toString()}")
    println("a2 = ${String(a2, Charsets.UTF_8)}")
}

toByteArray1()和toByteArray2()有什么区别?

如果我将字节发送到输出流中接收器会得到什么?

1 个答案:

答案 0 :(得分:3)

他们完全不同。

  • .toByteArray1()返回有符号长号的字节(因此它应该包含8个字节= 64位):

    println(0.toByteArray1().size) // 8
    println(1234.toByteArray1().size) // 8
    
  • .toByteArray2()首先将long转换为String,然后转换为以UTF-8编码的String个字符的字节数组(因为只有数字,所以它们被编码每个字节一个字节,在这种情况下,字节数组包含与字符串表示长度相同的字节数:

    println(0.toByteArray2().size) // 1
    println(-1234.toByteArray2().size) // 5
    println(123456789012.toByteArray2().size) // 12
    

当然,解码器应该不同,例如解码a1a2的示例。