gpt4 book ai didi

Java String.getBytes(charsetName) 与 String.getBytes(Charset 对象)

转载 作者:IT老高 更新时间:2023-10-28 20:51:45 29 4
gpt4 key购买 nike

我需要使用 UTF-8 编码将字符串编码为字节数组。我正在使用 Google guava,它的 Charsets 类已经为 UTF-8 编码定义了 Charset 实例。我有两种方法:

  1. String.getBytes(charsetName)

    try {        
    byte[] bytes = my_input.getBytes ( "UTF-8" );
    } catch ( UnsupportedEncodingException ex) {

    }
  2. String.getBytes(字符集对象)

    // Charsets.UTF_8 is an instance of Charset    

    byte[] bytes = my_input.getBytes ( Charsets.UTF_8 );

我的问题是我应该使用哪一个?它们返回相同的结果。对于方式 2 - 我不必尝试/捕获!我看了一下 Java 源代码,发现方式 1 和方式 2 的实现方式不同。

有人有什么想法吗?

最佳答案

如果您要使用字符串文字(例如“UTF-8”)......你不应该。而是使用第二个版本并提供来自 StandardCharsets 的常量值(特别是 StandardCharsets.UTF_8,在这种情况下)。

当字符集是动态时使用第一个版本。当您在编译时不知道字符集是什么时,就会出现这种情况;它由最终用户提供,从配置文件或系统属性等中读取。

在内部,这两种方法都在调用 StringCoding.encode() 的一个版本。 encode() 的第一个版本只是首先通过提供的名称查找 Charset,如果该字符集未知/不可用则抛出异常。

关于Java String.getBytes(charsetName) 与 String.getBytes(Charset 对象),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23316755/

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