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
,然后将String
字符以 UTF 编码转换为字节数组-8(因为只有数字,所以它们每个被编码一个字节),并且这种情况下的字节数组包含与字符串表示的长度相同的字节数:println(0.toByteArray2().size) // 1 println(-1234.toByteArray2().size) // 5 println(123456789012.toByteArray2().size) // 12
当然,解码器应该不同,就像在解码 a1
和 a2
的示例中一样。
关于kotlin - 从 Long 到 ByteArray 的两次转换有什么区别?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42001355/