百摩网
当前位置: 首页 生活百科

关于string的面试题(面试官String长度有限制吗)

时间:2023-05-24 作者: 小编 阅读量: 2 栏目名: 生活百科

面试官String长度有限制吗前言话说Java中String是有长度限制的,听到这里很多人不禁要问,String还有长度限制?是的有,而且在JVM编译中还有规范,而且有的家人们在面试的时候也遇到了,本人就遇到过面试的时候问这个的,。

前言

话说Java中String是有长度限制的,听到这里很多人不禁要问,String还有长度限制?是的有,而且在JVM编译中还有规范,而且有的家人们在面试的时候也遇到了,本人就遇到过面试的时候问这个的,而且在之前开发的中也真实地遇到过这个String长度限制的场景(将某固定文件转码成Base64的形式用字符串存储,在运行时需要的时候在转回来,当时文件比较大),那这个规范限制到底是怎么样的,咱们话不多说先䁖䁖去。

String

首先要知道String的长度限制我们就需要知道String是怎么存储字符串的,String其实是使用的一个char类型的数组来存储字符串中的字符的。

存储String的容器原来是它

那么String既然是数组存储那数组会有长度的限制吗?是的有限制,但是是在有先提条件下的,我们看看String中返回length的方法。

String类中的length方法

由此我们看到返回值类型是int类型,Java中定义数组是可以给数组指定长度的,当然不指定的话默认会根据数组元素来指定:

int[] arr1 = new int[10]; // 定义一个长度为10的数组int[] arr2 = {1,2,3,4,5}; // 那么此时数组的长度为5

整数在java中是有限制的,我们通过源码来看看int类型对应的包装类Integer可以看到,其长度最大限制为2^31 -1,那么说明了数组的长度是0~2^31-1,那么计算一下就是(2^31-1 = 2147483647 = 4GB)

Integer的取值范围

看到这我们尝试通过编码来验证一下上述观点。

以字面量形式定义字符串

以上是我通过定义字面量的形式构造的10万个字符的字符串,编译之后虚拟机提示报错,说我们的字符串长度过长,不是说好了可以存21亿个吗?为什么才10万个就报错了呢?

其实这里涉及到了JVM编译规范的限制了,其实JVM在编译时,如果我们将字符串定义成了字面量的形式,编译时JVM是会将其存放在常量池中,这时候JVM对这个常量池存储String类型做出了限制,接下来我们先看下手册是如何说的。

java虚拟机规范截图

常量池中,每个 cp_info 项的格式必须相同,它们都以一个表示 cp_info 类型的单字节 “tag”项开头。后面 info[]项的内容 由tag 的类型所决定。

java虚拟机规范手册常量类型表

我们可以看到 String类型的表示是 CONSTANT_String ,我们来看下CONSTANT_String具体是如何定义的。

这里定义的 u2 string_index 表示的是常量池的有效索引,其类型是CONSTANT_Utf8_info 结构体表示的,这里我们需要注意的是其中定义的length我们看下面这张图。

在class文件中u2表示的是无符号数占2个字节单位,我们知道1个字节占8位,2个字节就是16位 ,那么2个字节能表示的范围就是2^16- 1 = 65535 。范中class文件格式对u1、u2的定义的解释做了一下摘要:

这里对java虚拟机规摘要部分1、class文件中文件内容类型解释定义一组私有数据类型来表示 Class 文件的内容,它们包括 u1,u2 和 u4,分别代表了 1、2 和 4 个字节的无符号数。每个 Class 文件都是由 8 字节为单位的字节流组成,所有的 16 位、32 位和 64 位长度的数据将被构造成 2 个、4 个和 8 个 8 字节单位来表示。

2、程序异常处理的有效范围解释start_pc 和 end_pc 两项的值表明了异常处理器在 code[]数组中的有效范围。start_pc 必须是对当前 code[]数组中某一指令的操作码的有效索引,end_pc 要么是对当前 code[]数组中某一指令的操作码的有效索引,要么等于 code_length的值,即当前 code[]数组的长度。start_pc 的值必须比 end_pc 小。当程序计数器在范围[start_pc, end_pc)内时,异常处理器就将生效。即设 x 为异常句柄的有效范围内的值,x 满足:start_pc ≤ x < end_pc。实际上,end_pc 值本身不属于异常处理器的有效范围这点属于 Java 虚拟机历史上的一个设计缺陷:如果 Java 虚拟机中的一个方法的 code 属性的长度刚好是 65535个字节,并且以一个 1 个字节长度的指令结束,那么这条指令将不能被异常处理器所处理。不过编译器可以通过限制任何方法、实例初始化方法或类初始化方法的code[]数组最大长度为 65534,这样可以间接弥补这个 BUG。

注意:这里对个人认为比较重要的点做了标记,首先第一个加粗说白了就是说数组有效范围就是【0-65565】但是第二个加粗的地方又解释了,因为虚拟机还需要1个字节的指令作为结束,所以其实真正的有效范围是【0-65564】,这里要注意这里的范围仅限编译时期,如果你是运行时拼接的字符串是可以超出这个范围的。

接下来我们通过一个小实验来测试一下我们构建一个长度为65534的字符串,看看是否就能编译通过。首先通过一个for循环构建65534长度的字符串,在控制台打印后,我们通过自己度娘的一个在线字符统计工具计算了一下确实是65534个字符,如下:

然后我们将字符复制后以定义字面量的形式赋值给字符串,可以看到我们选择这些字符右下角显示的确实是65534,于是乎运行了一波,果然成功了。

看到这里我们来总结一下:问:字符串有长度限制吗?是多少?

答:首先字符串的内容是由一个字符数组 char[] 来存储的,由于数组的长度及索引是整数,且String类中返回字符串长度的方法length() 的返回值也是int ,所以通过查看java源码中的类Integer我们可以看到Integer的最大范围是2^31 -1,由于数组是从0开始的,所以数组的最大长度可以使【0~2^31-1】通过计算是大概4GB。

但是通过翻阅java虚拟机手册对class文件格式的定义以及常量池中对String类型的结构体定义我们可以知道对于索引定义了u2,就是无符号占2个字节,2个字节可以表示的最大范围是2^16 -1 = 65535。其实是65535,但是由于JVM需要1个字节表示结束指令,所以这个范围就为65534了。超出这个范围在编译时期是会报错的,但是运行时拼接或者赋值的话范围是在整形的最大范围。

解析到这里就告一段落了,如果觉得在下讲得对你有帮助的可以点一波关注,下方的小拇指点一波支持,如果发现有讲的不好的或者有什么遗漏的,欢迎评论区留言相互学习,进步,后期会不定期更新更多的技术编程相关的文章。

    推荐阅读
  • 翡翠锁寓意(翡翠锁寓意解说)

    翡翠锁寓意翡翠锁一般是叫长命锁,寓意健康长寿、吉祥幸福和聪明伶俐。其中,翡翠锁也有被雕刻成如意造型,寓意是万事如意。翡翠锁之所以能流行千年而受到人们的追捧,主要是其具有丰富且美好的寓意,并被人们赋予了平安富贵的概念,是长辈美好愿望的浓缩,紧紧地抓住了长辈疼爱宝宝的心理。对于每一对父母来说,孩子就是他们的心头肉,孩子能够平安长大,是父母最大的期望。

  • 巧妙解答高中数学立体几何(立体几何中常用性质)

    对称图形常见问题1中考易错点:轴对称、轴对称图形,及中心对称、中心对称图形概念和性质把握不准。2中考易错点:图形的轴对称或旋转问题,要充分运用其性质解题,即运用图形的“不变性”,在轴对称和旋转中角的大小不变,线段的长短不变。3中考易错点:将轴对称与全等混淆,关于直线对称与关于轴对称混淆。

  • 护肤品全国批发源头厂家(护肤品批发公司直销)

    护肤品全国批发源头厂家?接下来我们就一起去了解一下吧!

  • 五一快乐祝福语+老师(祝老师五一快乐的句子)

    愿欢快的歌声,时刻萦绕着您;愿欢乐年华,永远伴随您祝您劳动节愉快,今天小编就来聊一聊关于五一快乐祝福语+老师?劳动节,愿您身体健康,幸福美好,一生平安,永远快乐!海上行船有灯塔所以不怕浪,人生路上有老师所以不迷茫,劳动节到了,祝敬爱的老师劳动节快乐,身体健康,事事如意!您是一盏明灯,为我指明了知识的方向;劳动节到了,送上祝福,祝您劳动节快乐。

  • 女性尖锐性湿疣早期怎么治疗(如何治疗女性朋友的尖锐湿疣)

    很多的女性患者查出了尖锐湿疣,不知道这种病应该怎么办!既然查出来了,也不用过度的紧张,根据不同的病情,有不同的治疗方法,但一般治疗尖锐湿疣是用激光的。

  • 黑猫消费者投诉平台是什么(黑猫消费者投诉平台简述)

    以下内容大家不妨参考一二希望能帮到您!黑猫消费者投诉平台是什么黑猫投诉是新浪旗下的消费者服务平台,用户可以通过该平台投诉商家的不规范行为,同时还有企业信誉榜单,以帮助消费者进行消费行为抉择参考。2018年3月14日,微博和新浪网联合举办以“共建消费新生态”为主题的3·15论坛,双方联合推出的消费者服务平台黑猫投诉结束试运营,正式上线。2018年9月19日,黑猫投诉客户端iOS版在AppStore正式上线。

  • 目前主流的舆情监测软件有哪些(舆情监测系统源码的功能有哪些以及舆情监测的应用范围)

    舆情监测系统源码2)舆情数据处理子系统舆情数据处理子系统主要是针对采集子系统采集的数据进行整理、处理。以上这些是奇瑰网社区小编给大家介绍的舆情监测系统源码的功能有哪些以及舆情监测的应用范围的相关内容,想要知道更多舆情监测的信息,敬请继续留意我们的网站。

  • 神武炼丹的门派(神武炼丹炉灵气怎么练)

    神武炼丹炉灵气修炼攻略详解下面就和小编一起来看看吧,我来为大家科普一下关于神武炼丹的门派?神武手游中的炼丹炉是玩家把多余的装备和物品练成灵气丹,下面就和小编去了解神武手游中炼丹炉的玩法以及灵气丹的介绍。

  • 苦荞麦如何泡茶喝(苦荞麦泡茶喝的方法)

    苦荞麦如何泡茶喝?苦荞麦如何泡茶喝苦荞麦的种子在收取后不能直接泡水,应该对她进行适度加工以后再在泡水喝在加工苦荞麦种子是要把它里面的杂质全部去掉,然后放在无油无水的锅中用小火慢慢炒制,炒到它颜色加深以后取出降温。

  • 火龙果榴莲椰奶西米露的做法(火龙果榴莲椰奶西米露的做法和配方)

    1、将西米洗净,放入滚水锅中煮10分钟,煮的过程需不时搅拌防止粘锅,煮至西米还有少许白芯的时候关火再焖片刻,至西米熟透,呈一粒粒透明状时。