gpt4 book ai didi

kotlin - 从Long到ByteArray的两次转换之间有什么区别?

转载 作者:行者123 更新时间:2023-12-02 12:43:53 28 4
gpt4 key购买 nike

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

    关于kotlin - 从Long到ByteArray的两次转换之间有什么区别?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42001355/

    28 4 0
    Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
    广告合作:1813099741@qq.com 6ren.com