博客
关于我
关于Java中的getBytes()的原理理解以及演算
阅读量:161 次
发布时间:2019-02-27

本文共 679 字,大约阅读时间需要 2 分钟。

当你调用String.getBytes()时,Java会根据字符串的内容和指定的编码方式将每个字符转换为相应的字节。具体过程如下:

  • Java String的内部表示:Java String使用UTF-16编码存储字符,这意味着每个字符可能由1或2个16-bit值组成(即2或4个字节)。

  • 编码方式的选择String.getBytes()默认使用平台默认编码(通常是UTF-8),但可以指定其他编码方式。

  • 转换过程

    • 遍历字符串中的每个字符。
    • 对于每个字符,根据编码方式将其转换为字节。
    • 不同编码方式会影响结果,例如UTF-8处理字符的方式与ISO-8859-1不同。
  • 示例分析:以字符串“abcD热爱技术”为例:

    • 'a' -> 97
    • 'b' -> 98
    • 'c' -> 99
    • 'D' -> 68
    • '热' -> 在UTF-8中为0xEF 0xBF 0xBD
    • '爱' -> 0xE4 0xA4 0xB5
    • '技术' -> 0xE7 0xA8 0xA2
    • 继续类推,直到所有字符转换完成。
  • 不同编码方式的影响:使用不同的编码方式会导致字节数组的不同。例如,使用ISO-8859-1可能会有不同的结果,而UTF-8则能更准确地表示所有字符。

  • 手动演算示例

    String str = "abcD热爱技术";byte[] bytes = str.getBytes("UTF-8");// bytes数组将包含上述每个字符转换后的字节

    这段代码将生成一个字节数组,包含所有字符转换后的结果。

  • 通过以上步骤,你可以理解字符串转换为字节数组的原理,并根据需要选择合适的编码方式。

    转载地址:http://autb.baihongyu.com/

    你可能感兴趣的文章
    npm scripts 使用指南
    查看>>
    npm should be run outside of the node repl, in your normal shell
    查看>>
    npm start运行了什么
    查看>>
    npm WARN deprecated core-js@2.6.12 core-js@<3.3 is no longer maintained and not recommended for usa
    查看>>
    npm 下载依赖慢的解决方案(亲测有效)
    查看>>
    npm 安装依赖过程中报错:Error: Can‘t find Python executable “python“, you can set the PYTHON env variable
    查看>>
    npm.taobao.org 淘宝 npm 镜像证书过期?这样解决!
    查看>>
    npm—小记
    查看>>
    npm上传自己的项目
    查看>>
    npm介绍以及常用命令
    查看>>
    NPM使用前设置和升级
    查看>>
    npm入门,这篇就够了
    查看>>
    npm切换到淘宝源
    查看>>
    npm切换源淘宝源的两种方法
    查看>>
    npm前端包管理工具简介---npm工作笔记001
    查看>>
    npm包管理深度探索:从基础到进阶全面教程!
    查看>>
    npm升级以及使用淘宝npm镜像
    查看>>
    npm发布包--所遇到的问题
    查看>>
    npm发布自己的组件UI包(详细步骤,图文并茂)
    查看>>
    npm和package.json那些不为常人所知的小秘密
    查看>>