日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當(dāng)前位置:首頁 > > 架構(gòu)師社區(qū)
[導(dǎo)讀]話說Java中String是有長(zhǎng)度限制的,聽到這里很多人不禁要問,String還有長(zhǎng)度限制?是的有,而且在JVM編譯中還有規(guī)范,而且有的家人們?cè)诿嬖嚨臅r(shí)候也遇到了。本人就遇到過面試的時(shí)候問這個(gè)的,而且在之前開發(fā)的中也真實(shí)地遇到過這個(gè)String長(zhǎng)度限制的場(chǎng)景(將某固定文件轉(zhuǎn)碼成Base64的形式用字符串存儲(chǔ),在運(yùn)行時(shí)需要的時(shí)候在轉(zhuǎn)回來,當(dāng)時(shí)文件比較大),那這個(gè)規(guī)范限制到底是怎么樣的,咱們?cè)挷欢嗾f先??去。 前言 話說Java中String是有長(zhǎng)度限制的,聽到這里很多人不禁要問,String還有長(zhǎng)度限制?是的有,而且在JVM編譯中還有規(guī)范,而且有的家人們?cè)诿嬖嚨臅r(shí)候也遇到了。 本人就遇到過面試的時(shí)候問這個(gè)的

   
來源:www.toutiao.com/i6893014573322863111

前言

話說Java中String是有長(zhǎng)度限制的,聽到這里很多人不禁要問,String還有長(zhǎng)度限制?是的有,而且在JVM編譯中還有規(guī)范,而且有的家人們?cè)诿嬖嚨臅r(shí)候也遇到了。
本人就遇到過面試的時(shí)候問這個(gè)的,而且在之前開發(fā)的中也真實(shí)地遇到過這個(gè)String長(zhǎng)度限制的場(chǎng)景(將某固定文件轉(zhuǎn)碼成Base64的形式用字符串存儲(chǔ),在運(yùn)行時(shí)需要的時(shí)候在轉(zhuǎn)回來,當(dāng)時(shí)文件比較大),那這個(gè)規(guī)范限制到底是怎么樣的,咱們?cè)挷欢嗾f先??去。

String

首先要知道String的長(zhǎng)度限制我們就需要知道String是怎么存儲(chǔ)字符串的,String其實(shí)是使用的一個(gè)char類型的數(shù)組來存儲(chǔ)字符串中的字符的。
面試官:String長(zhǎng)度有限制嗎?是多少?還好我看過
存儲(chǔ)String的容器原來是它
那么String既然是數(shù)組存儲(chǔ)那數(shù)組會(huì)有長(zhǎng)度的限制嗎?是的有限制,但是是在有先提條件下的,我們看看String中返回length的方法。
面試官:String長(zhǎng)度有限制嗎?是多少?還好我看過
String類中的length方法
由此我們看到返回值類型是int類型,Java中定義數(shù)組是可以給數(shù)組指定長(zhǎng)度的,當(dāng)然不指定的話默認(rèn)會(huì)根據(jù)數(shù)組元素來指定:

   
int[]?arr1?=?new?int[10];?//?定義一個(gè)長(zhǎng)度為10的數(shù)組
int[]?arr2?=?{1,2,3,4,5};?//?那么此時(shí)數(shù)組的長(zhǎng)度為5
整數(shù)在java中是有限制的,我們通過源碼來看看int類型對(duì)應(yīng)的包裝類Integer可以看到,其長(zhǎng)度最大限制為2^31 -1,那么說明了數(shù)組的長(zhǎng)度是0~2^31-1,那么計(jì)算一下就是(2^31-1 = 2147483647 = 4GB)
面試官:String長(zhǎng)度有限制嗎?是多少?還好我看過
Integer的取值范圍
看到這我們嘗試通過編碼來驗(yàn)證一下上述觀點(diǎn)。
面試官:String長(zhǎng)度有限制嗎?是多少?還好我看過
以字面量形式定義字符串
以上是我通過定義字面量的形式構(gòu)造的10萬個(gè)字符的字符串,編譯之后虛擬機(jī)提示報(bào)錯(cuò),說我們的字符串長(zhǎng)度過長(zhǎng),不是說好了可以存21億個(gè)嗎?為什么才10萬個(gè)就報(bào)錯(cuò)了呢?
其實(shí)這里涉及到了JVM編譯規(guī)范的限制了,其實(shí)JVM在編譯時(shí),如果我們將字符串定義成了字面量的形式,編譯時(shí)JVM是會(huì)將其存放在常量池中,這時(shí)候JVM對(duì)這個(gè)常量池存儲(chǔ)String類型做出了限制,接下來我們先看下手冊(cè)是如何說的。
面試官:String長(zhǎng)度有限制嗎?是多少?還好我看過
java虛擬機(jī)規(guī)范截圖
常量池中,每個(gè) cp_info 項(xiàng)的格式必須相同,它們都以一個(gè)表示 cp_info 類型的單字節(jié) “tag”項(xiàng)開頭。后面 info[]項(xiàng)的內(nèi)容 由tag 的類型所決定。
面試官:String長(zhǎng)度有限制嗎?是多少?還好我看過
java虛擬機(jī)規(guī)范手冊(cè)常量類型表
我們可以看到 String類型的表示是 CONSTANT_String ,我們來看下CONSTANT_String具體是如何定義的。
面試官:String長(zhǎng)度有限制嗎?是多少?還好我看過
這里定義的 u2 string_index 表示的是常量池的有效索引,其類型是CONSTANT_Utf8_info 結(jié)構(gòu)體表示的,這里我們需要注意的是其中定義的length我們看下面這張圖。歷史文章:200期階段匯總
面試官:String長(zhǎng)度有限制嗎?是多少?還好我看過
在class文件中u2表示的是無符號(hào)數(shù)占2個(gè)字節(jié)單位,我們知道1個(gè)字節(jié)占8位,2個(gè)字節(jié)就是16位 ,那么2個(gè)字節(jié)能表示的范圍就是2^16- 1 = 65535 。范中class文件格式對(duì)u1、u2的定義的解釋做了一下摘要:
這里對(duì)java虛擬機(jī)規(guī)摘要部分

1、class文件中文件內(nèi)容類型解釋

定義一組私有數(shù)據(jù)類型來表示 Class 文件的內(nèi)容,它們包括 u1,u2 和 u4,分別代 表了 1、2 和 4 個(gè)字節(jié)的無符號(hào)數(shù)。
每個(gè) Class 文件都是由 8 字節(jié)為單位的字節(jié)流組成,所有的 16 位、32 位和 64 位長(zhǎng)度的數(shù) 據(jù)將被構(gòu)造成 2 個(gè)、4 個(gè)和 8 個(gè) 8 字節(jié)單位來表示。

2、程序異常處理的有效范圍解釋

start_pc 和 end_pc 兩項(xiàng)的值表明了異常處理器在 code[]數(shù)組中的有效范圍。
start_pc 必須是對(duì)當(dāng)前 code[]數(shù)組中某一指令的操作碼的有效索引,end_pc 要 么是對(duì)當(dāng)前 code[]數(shù)組中某一指令的操作碼的有效索引,要么等于 code_length 的值,即當(dāng)前 code[]數(shù)組的長(zhǎng)度。start_pc 的值必須比 end_pc 小。
當(dāng)程序計(jì)數(shù)器在范圍 [start_pc, end_pc)內(nèi)時(shí),異常處理器就將生效。即設(shè) x 為 異常句柄的有效范圍內(nèi)的值,x 滿足: start_pc ≤ x < end_pc。
實(shí)際上,end_pc 值本身不屬于異常處理器的有效范圍這點(diǎn)屬于 Java 虛擬機(jī)歷史上 的一個(gè)設(shè)計(jì)缺陷:如果 Java 虛擬機(jī)中的一個(gè)方法的 code 屬性的長(zhǎng)度剛好是 65535 個(gè)字節(jié),并且以一個(gè) 1 個(gè)字節(jié)長(zhǎng)度的指令結(jié)束,那么這條指令將不能被異常處理器 所處理。
不過編譯器可以通過限制任何方法、實(shí)例初始化方法或類初始化方法的 code[]數(shù)組最大長(zhǎng)度為 65534,這樣可以間接彌補(bǔ)這個(gè) BUG。
注意:這里對(duì)個(gè)人認(rèn)為比較重要的點(diǎn)做了標(biāo)記,首先第一個(gè)加粗說白了就是說數(shù)組有效范圍就是【0-65565】但是第二個(gè)加粗的地方又解釋了,因?yàn)樘摂M機(jī)還需要1個(gè)字節(jié)的指令作為結(jié)束,所以其實(shí)真正的有效范圍是【0-65564】,這里要注意這里的范圍僅限編譯時(shí)期,如果你是運(yùn)行時(shí)拼接的字符串是可以超出這個(gè)范圍的。
接下來我們通過一個(gè)小實(shí)驗(yàn)來測(cè)試一下我們構(gòu)建一個(gè)長(zhǎng)度為65534的字符串,看看是否就能編譯通過。歷史文章:200期階段匯總
首先通過一個(gè)for循環(huán)構(gòu)建65534長(zhǎng)度的字符串,在控制臺(tái)打印后,我們通過自己度娘的一個(gè)在線字符統(tǒng)計(jì)工具計(jì)算了一下確實(shí)是65534個(gè)字符,如下:
面試官:String長(zhǎng)度有限制嗎?是多少?還好我看過
面試官:String長(zhǎng)度有限制嗎?是多少?還好我看過
然后我們將字符復(fù)制后以定義字面量的形式賦值給字符串,可以看到我們選擇這些字符右下角顯示的確實(shí)是65534,于是乎運(yùn)行了一波,果然成功了。
面試官:String長(zhǎng)度有限制嗎?是多少?還好我看過
面試官:String長(zhǎng)度有限制嗎?是多少?還好我看過
看到這里我們來總結(jié)一下:
問:字符串有長(zhǎng)度限制嗎?是多少?
答:首先字符串的內(nèi)容是由一個(gè)字符數(shù)組 char[] 來存儲(chǔ)的,由于數(shù)組的長(zhǎng)度及索引是整數(shù),且String類中返回字符串長(zhǎng)度的方法length() 的返回值也是int ,所以通過查看java源碼中的類Integer我們可以看到Integer的最大范圍是2^31 -1,由于數(shù)組是從0開始的,所以數(shù)組的最大長(zhǎng)度可以使【0~2^31】通過計(jì)算是大概4GB。
但是通過翻閱java虛擬機(jī)手冊(cè)對(duì)class文件格式的定義以及常量池中對(duì)String類型的結(jié)構(gòu)體定義我們可以知道對(duì)于索引定義了u2,就是無符號(hào)占2個(gè)字節(jié),2個(gè)字節(jié)可以表示的最大范圍是2^16 -1 = 65535。
其實(shí)是65535,但是由于JVM需要1個(gè)字節(jié)表示結(jié)束指令,所以這個(gè)范圍就為65534了。超出這個(gè)范圍在編譯時(shí)期是會(huì)報(bào)錯(cuò)的,但是運(yùn)行時(shí)拼接或者賦值的話范圍是在整形的最大范圍。

特別推薦一個(gè)分享架構(gòu)+算法的優(yōu)質(zhì)內(nèi)容,還沒關(guān)注的小伙伴,可以長(zhǎng)按關(guān)注一下:

面試官:String長(zhǎng)度有限制嗎?是多少?還好我看過

面試官:String長(zhǎng)度有限制嗎?是多少?還好我看過

面試官:String長(zhǎng)度有限制嗎?是多少?還好我看過

長(zhǎng)按訂閱更多精彩▼

面試官:String長(zhǎng)度有限制嗎?是多少?還好我看過

如有收獲,點(diǎn)個(gè)在看,誠摯感謝

免責(zé)聲明:本文內(nèi)容由21ic獲得授權(quán)后發(fā)布,版權(quán)歸原作者所有,本平臺(tái)僅提供信息存儲(chǔ)服務(wù)。文章僅代表作者個(gè)人觀點(diǎn),不代表本平臺(tái)立場(chǎng),如有問題,請(qǐng)聯(lián)系我們,謝謝!

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除( 郵箱:macysun@21ic.com )。
換一批
延伸閱讀

全球嵌入式技術(shù)領(lǐng)域的年度盛會(huì)2026嵌入式世界展(Embedded World 2026,簡(jiǎn)稱EW26)于3月10日至12日在德國紐倫堡成功舉辦。作為物聯(lián)網(wǎng)和邊緣AI領(lǐng)域的領(lǐng)先企業(yè),Silicon Labs(亦稱“芯科科...

關(guān)鍵字: 物聯(lián)網(wǎng) 邊緣AI 嵌入式

3月10日至12日,2026年嵌入式世界展(Embedded World 2026,簡(jiǎn)稱EW26)在德國紐倫堡展覽中心成功舉辦。作為領(lǐng)先的邊緣AI與智能音頻等媒體處理技術(shù)和芯片解決方案提供商,XMOS以沉浸式演示與技術(shù)交...

關(guān)鍵字: 邊緣AI 智能音頻 嵌入式

在嵌入式系統(tǒng)開發(fā)中,SoC(System on Chip)的多樣性始終是橫亙?cè)陂_發(fā)者面前的難題。以某工業(yè)物聯(lián)網(wǎng)網(wǎng)關(guān)項(xiàng)目為例,其需同時(shí)支持NXP i.MX8M、Rockchip RK3566和Allwinner H616三...

關(guān)鍵字: Platform Driver模型 嵌入式

在高性能網(wǎng)絡(luò)編程領(lǐng)域,事件驅(qū)動(dòng)模型以其高效的I/O多路復(fù)用能力成為主流范式。不同于傳統(tǒng)的多線程/多進(jìn)程阻塞模型,事件驅(qū)動(dòng)通過單一線程監(jiān)聽多個(gè)文件描述符的狀態(tài)變化,以非阻塞方式處理I/O事件,顯著減少了上下文切換開銷和資源...

關(guān)鍵字: 事件驅(qū)動(dòng) C語言

在非易失性存儲(chǔ)器領(lǐng)域,EEPROM(電可擦除可編程只讀存儲(chǔ)器)曾長(zhǎng)期占據(jù)主流地位,廣泛應(yīng)用于各類電子設(shè)備的參數(shù)存儲(chǔ)、日志記錄等場(chǎng)景。但隨著工業(yè)控制、汽車電子、醫(yī)療設(shè)備等領(lǐng)域?qū)Υ鎯?chǔ)性能提出更高要求,F(xiàn)RAM(鐵電隨機(jī)存取存...

關(guān)鍵字: 存儲(chǔ)器 可編程 嵌入式

康佳特將aReady.COM擴(kuò)展至Arm架構(gòu)模塊,基于恩智浦i.MX 95處理器打造應(yīng)用就緒的軟硬件構(gòu)建模塊,集成操作系統(tǒng)、系統(tǒng)整合與IoT連接能力,賦能高價(jià)值應(yīng)用快速落地

關(guān)鍵字: 處理器 IoT 嵌入式

3月12日,2026年中國家電及消費(fèi)電子博覽會(huì)(以下簡(jiǎn)稱:AWE 2026)在上海盛大開幕。展會(huì)現(xiàn)場(chǎng),場(chǎng)景化、系統(tǒng)化、一體化的家電解決方案成為行業(yè)焦點(diǎn),消費(fèi)者對(duì)家電的關(guān)注也已從基礎(chǔ)的尺寸匹配,延伸至對(duì)“空間秩序感”和“視...

關(guān)鍵字: 消費(fèi)電子 蒸烤箱 嵌入式

超高效NPU IP在資源受限設(shè)備中推進(jìn)邊緣AI,因而獲得認(rèn)可

關(guān)鍵字: 人工智能 嵌入式 NPU

上海2026年3月12日 /美通社/ -- 3月12日,2026中國家電及消費(fèi)電子博覽會(huì)(AWE 2026)在上海新國際博覽中心和東方樞紐國際商務(wù)合作區(qū)展區(qū)正式啟幕。本屆展會(huì)以"AI科技?慧享未來"為...

關(guān)鍵字: 西門子 博世 嵌入式 洗碗機(jī)
關(guān)閉