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

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()有什么区别?

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

他们完全不同。

  • .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例子。