博客
关于我
关于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/

    你可能感兴趣的文章
    OpenStack安装部署实战
    查看>>
    OpenStack实践系列⑨云硬盘服务Cinder
    查看>>
    OpenStack架构
    查看>>
    OpenStack版本升级与故障排查实战
    查看>>
    Openstack的HA解决方案【替换原有的dashboard】
    查看>>
    OpenStack的基本概念与架构详解
    查看>>
    Openstack的视频学习
    查看>>
    OpenStack自动化安装部署实战(附OpenStack实验环境)
    查看>>
    openstack虚拟机迁移live-migration中libvirt配置
    查看>>
    OpenStack项目管理实战
    查看>>
    OpenStreetMap初探(一)——了解OpenStreetMap
    查看>>
    openSUSE 13.1 Milestone 2 发布
    查看>>
    openSUSE推出独立 GUI 包管理工具:YQPkg,简化了整个软件包管理流程
    查看>>
    OpenVP共用账号 一个账号多台电脑登录
    查看>>
    OpenVSwtich(OVS)Vlan间路由实战 附实验环境
    查看>>
    Openwrt LuCI模块练习详细步骤
    查看>>
    openwrt_git_pull命令提示merger冲突时如何解决?
    查看>>
    OpenWrt包管理软件opkg的使用(极路由)
    查看>>
    OpenWrt固件编译刷机完全总结
    查看>>
    Open××× for Linux搭建之二
    查看>>