电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

Java String保存字符串的機制

瀏覽:11日期:2022-08-12 11:27:06
String 真的是 Immutable 的嗎

Java 中的 Unicode 字符串會按照 Latin1(所有的字符都小于 0xFF 時)或者 UTF16 的編碼格式保存在 String 中,保存為 byte 數組:

private final byte[] value;

通常所說的 Immutable 都是指 final bytes 在 String 初始化后就不會修改,所有字符串的相關操作都是不會修改原數組而是創建新的副本。

但是數組元素理論上是可以修改的,比如下面通過反射的方式,將字符串常量 abc 修改為 Abc:

public static void main(String[] args) { setFirstValueToA('abc');String replaced = new String('abc');System.out.println(replaced); // Abc }private static void setFirstValueToA(String str) {Class<String> stringClass = String.class;try { Field value = stringClass.getDeclaredField('value'); value.setAccessible(true); byte[] bytes = (byte[]) value.get(str); bytes[0] = 0x41; // A } catch (NoSuchFieldException | IllegalAccessException e) { e.printStackTrace();} }字符串數組如何保存為字節數組

通過如下代碼測試幾個字符串數組:

public static void main(String[] args) {printString('abc');printString('中文');printString('abc中文');printString('abc'); } private static void printString(String str) {System.out.println('======>' + str);// return the UTF-16 char[] sizeSystem.out.println('length: ' + str.length());// Use default Encoding (UTF-8)System.out.println('getBytes: ' + str.getBytes().length);// Convert UTF-16 char[] to charSystem.out.println('codePointCount: ' + str.codePointCount(0, str.length()));// Get the UTF-16 char[]System.out.println('toCharArray: ' + str.toCharArray().length);// The UTF-16 char[] to bytesSystem.out.println('internal value: ' + getStringInternalValueLength(str)); }

結果如下:

Java String保存字符串的機制

internal value

首先解釋下 String 的 value 字段計算方式:

所有字符都小于 0xFF 時,采用 Latin1 Character Encoding 來保存 Unicode code point,也就是每個字符都用一個 byte 來保存。比如“ABC” 上述條件不滿足時,采用 UTF-16 Character Encoding 來保存,也就是每個字符都用 2 個或者 4 個 byte 來保存。

Unicode 是 Coded Character Set,將幾乎所有的人類文字映射到 code point 符號,通常格式為 U+xxxx,xxxx 為 16 進制整數,表達范圍為 U+0000~U+10FFFF。code point 符號是文字的規范化標記,但是實際保存時肯定還是要保存為字節數組的。這些不同的保存方式就是 Character Encoding,比如 UTF-8,還有 Java String 內部采用的 UTF-16。

UTF-16 是一種將 Unicode code point 表達成字符數組的編碼方式,對于 U+0000~U+FFFF,直接按照 2 個字節保存(細分的話還有大端字節序和小端字節序的區別);對于 U+10000~U+10FFFF,會先轉化為一對 U+D800~U+DFFF 范圍內的 code point(surrogate pair),再將這兩個 code point 按照前面的規則保存。之所以選擇這個范圍,是因為這個 Unicode 區間還沒有被分配有效的字符,因此可以和前面的規則區分。

“中文”這兩個漢字的 Unicode code point 非別為 U+4E2d、U+6587,大于 0xFF,所以保存 byte 長度為 4;'abc中文' 中存在不滿足條件的字符,所以全部用 UTF-16 保存,它們都是 2 個 byte 的,所以長度為 10。

“☺” 的 Unicode code point 為 U+1F60A,根據 UTF-16 規范,U+10000~U+10FFFF 需要轉化為 surrogate pair 之后再保存成 byte, 轉換后為 U+D83D、U+DE0A,因此 'abc' 的字節長度為 10。

toCharArray()

Java 中 char 的大小為 2 個字節,剛好可以表示一個 U+0000~U+FFFF 的 Unicode 符號。

Latin1 編碼時,char 數組為 byte 數組的填充,高字節為 0;UTF-16 編碼時,相當于轉化過 surrogate pair 后的 Unicode 編碼數組,其中 0xD800~0xDFFF 范圍內的為 surrogate 字符。

“abc” 時為 Latin1 編碼,所以 char 數組大小等于 bytes 數組;“abc中文” 時為 UTF-16 編碼,所以 char 數組大小等于 bytes 數組的一半。

codePointCount()

toCharArray 方法將轉化后的 surrogate pair 也算在內,因此實際長度可能大于字符長度。而 codePointCount 就能去除 surrogate pair 的影響,返回初始的字符長度,它會將連續兩個 surrogate pair 只計數一次。

String.length

該方法就是 toCharArray 數組的長度,受到 surrogate pair 的影響,可能大于字符長度。

str.getBytes().length

String 內部是通過 UTF-16 編碼保存的字節數組,當通過 getBytes 方法返回時,是需要指定 Encoding 的,默認采用 UTF-8,因此會將 UTF-16 的字節數組轉化為 UTF-8 的字節數組,每個 Unicode 符號在 UTF-8 編碼后長度為 1~4 字節。

System.out.println('abc'.getBytes(UTF_8).length); // 3System.out.println('中'.getBytes(UTF_8).length); // 3System.out.println('文'.getBytes(UTF_8).length); // 3System.out.println(''.getBytes(UTF_8).length); // 4 最后

到此這篇關于Java String保存字符串的機制的文章就介紹到這了,更多相關Java String保存字符串內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Java
相關文章:
主站蜘蛛池模板: 档案密集柜_手动密集柜_智能密集柜_内蒙古档案密集柜-盛隆柜业内蒙古密集柜直销中心 | 色油机-色母机-失重|称重式混料机-称重机-米重机-拌料机-[东莞同锐机械]精密计量科技制造商 | 沈阳庭院景观设计_私家花园_别墅庭院设计_阳台楼顶花园设计施工公司-【沈阳现代时园艺景观工程有限公司】 | 广东教师资格网-广东教师资格证考试网 | 影合社-影视人的内容合作平台 | 北京网站建设-企业网站建设-建站公司-做网站-北京良言多米网络公司 | 体感VRAR全息沉浸式3D投影多媒体展厅展会游戏互动-万展互动 | MES系统工业智能终端_生产管理看板/安灯/ESOP/静电监控_讯鹏科技 | 河南新乡德诚生产厂家主营震动筛,振动筛设备,筛机,塑料震动筛选机 | 影像测量仪_三坐标测量机_一键式二次元_全自动影像测量仪-广东妙机精密科技股份有限公司 | 福州时代广告制作装饰有限公司-福州广告公司广告牌制作,福州展厅文化墙广告设计, | 耐酸碱胶管_耐腐蚀软管总成_化学品输送软管_漯河利通液压科技耐油耐磨喷砂软管|耐腐蚀化学软管 | 云杂志网-学术期刊-首页 | 岛津二手液相色谱仪,岛津10A液相,安捷伦二手液相,安捷伦1100液相-杭州森尼欧科学仪器有限公司 | 蜂蜜瓶-玻璃瓶-玻璃瓶厂-玻璃瓶生产厂家-徐州贵邦玻璃制品有限公司 | 施工电梯_齿条货梯_烟囱电梯_物料提升机-河南大诚机械制造有限公司 | 济南网站建设_济南网站制作_济南网站设计_济南网站建设公司_富库网络旗下模易宝_模板建站 | 东莞螺杆空压机_永磁变频空压机_节能空压机_空压机工厂批发_深圳螺杆空压机_广州螺杆空压机_东莞空压机_空压机批发_东莞空压机工厂批发_东莞市文颖设备科技有限公司 | 越南专线物流_东莞国际物流_东南亚专线物流_行通物流 | 碳钢法兰厂家,非标法兰,定制异型,法兰生产厂家-河北九瑞管道 | 蓝米云-专注于高性价比香港/美国VPS云服务器及海外公益型免费虚拟主机 | 专业广州网站建设,微信小程序开发,一物一码和NFC应用开发、物联网、外贸商城、定制系统和APP开发【致茂网络】 | 酸度计_PH计_特斯拉计-西安云仪 纯水电导率测定仪-万用气体检测仪-低钠测定仪-米沃奇科技(北京)有限公司www.milwaukeeinst.cn | 【孔氏陶粒】建筑回填陶粒-南京/合肥/武汉/郑州/重庆/成都/杭州陶粒厂家 | 称重传感器,测力传感器,拉压力传感器,压力变送器,扭矩传感器,南京凯基特电气有限公司 | 凝胶成像仪,化学发光凝胶成像系统,凝胶成像分析系统-上海培清科技有限公司 | 济南铝方通-济南铝方通价格-济南方通厂家-山东鲁方通建材有限公司 | X光检测仪_食品金属异物检测机_X射线检测设备_微现检测 | 拉力机-万能试验机-材料拉伸试验机-电子拉力机-拉力试验机厂家-冲击试验机-苏州皖仪实验仪器有限公司 | 冷轧机|两肋冷轧机|扁钢冷轧机|倒立式拉丝机|钢筋拔丝机|收线机-巩义市华瑞重工机械制造有限公司 | 电子海图系统-电梯检验系统-智慧供热系统开发-商品房预售资金监管系统 | 贴片电容-贴片电阻-二三极管-国巨|三星|风华贴片电容代理商-深圳伟哲电子 | 机械立体车库租赁_立体停车设备出租_智能停车场厂家_春华起重 | 台式核磁共振仪,玻璃软化点测定仪,旋转高温粘度计,测温锥和测温块-上海麟文仪器 | 昆明化妆培训-纹绣美甲-美容美牙培训-昆明博澜培训学校 | 长城人品牌官网| 应急灯_消防应急灯_应急照明灯_应急灯厂家-大成智慧官网 | 激光内雕_led玻璃_发光玻璃_内雕玻璃_导光玻璃-石家庄明晨三维科技有限公司 激光内雕-内雕玻璃-发光玻璃 | 东莞市超赞电子科技有限公司 全系列直插/贴片铝电解电容,电解电容,电容器 | 中药超微粉碎机(中药细胞级微粉碎)-百科 | 污水处理设备维修_污水处理工程改造_机械格栅_过滤设备_气浮设备_刮吸泥机_污泥浓缩罐_污水处理设备_污水处理工程-北京龙泉新禹科技有限公司 |