首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

字符串常量池_字符串常量池溢出

每当我们创建字符串常量时,JVM会首先检查字符串常量池,如果该字符串已经存在常量池中,那么就直接返回常量池中的实例引用。如果字符串不存在常量池中,就会实例化该字符串并且将其放到常量池中。...由于String字符串的不可变性我们可以十分肯定常量池中一定不存在两个相同的字符串(这点对理解上面至关重要)。 Java中的常量池,实际上分为两种形态:静态常量池和运行时常量池。...chenssy字符串常量。...分析:因为例子中的s0和s1中的”helloworld”都是字符串常量,它们在编译期就被确定了,所以s0==s1为true;而”hello”和”world”也都是字符串常量,当一个字符串由多个字符串常量连接而成时...,它自己肯定也是字符串常量,所以s2也同样在编译期就被解析为一个字符串常量,所以s2也是常量池中”helloworld”的一个引用。

62240
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Java字符串常量池_字符串常量池溢出

    在Java的内存分配中,总共3种常量池: Java 常量池详解(二)class文件常量池 和 Java 常量池详解(三)class运行时常量池 1.字符串常量池(String Constant Pool...) 在JDK1.7之前运行时常量池逻辑包含字符串常量池存放在方法区, 此时hotspot虚拟机对方法区的实现为永久代 在JDK1.7 字符串常量池被从方法区拿到了堆中, 这里没有提到运行时常量池,也就是说字符串常量池被单独拿到堆...在JDK6.0及之前版本,字符串常量池是放在Perm Gen区(也就是方法区)中; 在JDK7.0版本,字符串常量池被移到了堆中了。至于为什么移到堆内,大概是由于方法区的内存空间太小了。...(堆内是可以进行回收的,然后方法区也是能回收的,但是本身区域内存比较少,如果用的字符串常量太多了,也会抛java.lang.OutOfMemoryError:PermGenspace 异常) 1.2:字符串常量池是什么...字符串常量由一个一个字符组成,放在了StringTable上。

    1.1K30

    jvm常量池和字符串常量池_常量池中的字符串是对象吗

    作为最常用也是最基础的引用数据类型,JVM为String提供了字符串常量池来提高性能,本篇文章我们一起从底层JVM中认识并学习字符串常量池的概念和设计原理。...JVM层面提供了字符串常量池。...实现原理 为了提高性能并减少内存的开销,JVM在实例化字符串常量时进行了一系列的优化操作: 在JVM层面为字符串提供字符串常量池,可以理解为是一个缓存区; 创建字符串常量时,JVM会检查字符串常量池中是否存在这个字符串...; 若字符串常量池中存在该字符串,则直接返回引用实例;若不存在,先实例化该字符串,并且,将该字符串放入字符串常量池中,以便于下次使用时,直接取用,达到缓存快速使用的效果。...变化 在JDK1.7前,运行时常量池+字符串常量池是存放在方法区中,HotSpot VM对方法区的实现称为永久代。 在JDK1.7中,字符串常量池从方法区移到堆中,运行时常量池保留在方法区中。

    52120

    jvm字符串常量池_java 常量

    字符串 字符串字面量:就是指这个字符串本身,比如”Java”,”Hello”。...字符串对象:比如new String(“abc”),或者直接String s=”str”,后面的”str”也是一个字符串对象。 字符串引用:引用就是一个变量,指向对应的字符串对象。...这两项就是java和abcd这两个字符串的字面量。 而符号引用也是一些常量,比如全限定类名,字段的名称和描述符,方法的名称和描述符。 这是类名。 这是变量名。...c=”java”; String d=”abcd”; String e=”java”; String f=new String(“java”); } } 运行时常量池 && 字符串常量池 class常量池被加载到内存后...意思是当一个字符串对象调用intern方法,如果池中已经存在值相等(通过String的equal函数比较)的字符串常量,就返回常量池中的常量,也就是堆中对应实例的引用。否则将这个字符串加入常量池。

    52620

    字符串常量

    我直接否定了三妹的答案,“使用 new 关键字创建一个字符串对象时,Java 虚拟机会先在字符串常量池中查找有没有‘二哥’这个字符串对象,如果有,就不会在字符串常量池中创建‘二哥’这个对象了,直接在堆中创建一个...“如果没有,先在字符串常量池中创建一个‘二哥’的字符串对象,然后再在堆中创建一个‘二哥’的字符串对象,然后将堆中这个‘二哥’的字符串对象地址返回赋值给变量 s。”...“三妹”这个字符串对象,如果有,则不创建任何对象,直接将字符串常量池中这个“三妹”的对象地址返回,赋给变量 s;如果没有,在字符串常量池中创建“三妹”这个对象,然后将其地址返回,赋给变量 s。...“那哥,字符串常量池在内存中的什么位置呢?”三妹问。 我说,“三妹,你这个问题问得好呀!” 在 Java 8 之前,字符串常量池在永久代中。 ?...“那关于字符串常量池,就先说这么多吧,是不是还挺有意思的。”我说。 “是的,我现在是彻底搞懂了字符串常量池,哥,你真棒!”三妹说。

    50540

    字符串常量池 运行时常量池_常量池中的字符串是对象吗

    字符串常量池 StringTable 概述 常量池在java用于保存在编译期已确定的,已编译的class文件中的一份数据。...,无法进行扩容操作,并且字符串种类复杂,很可能发生哈希碰撞现象,一旦字符串在哈希表中形成了链表等数据结构,就会使字符串常量池的性能下降,所以字符串常量池中需要加入垃圾回收机制。...这个后面重点谈 Java 6及以前,字符串常量池存放在永久代 Java 7中 Oracle的工程师对字符串池的逻辑做了很大的改变,即将字符串常量池的位置调整到Java堆内 所有的字符串都保存在堆...变量拼接的原理是StringBuilder 如果拼接的结果调用intern()方法,根据该字符串是否在常量池中存在,分为: 如果存在,则返回字符串常量池中的地址 如果字符串常量池中不存在该字符串,则在常量池中创建一份...如果不是用双引号声明的String对象,可以使用String提供的intern方法:intern方法会从字符串常量池中查询当前字符串是否存在,若不存在就会将当前字符串放入常量池中。

    26520

    String:字符串常量

    String:字符串常量池 作为最基础的引用数据类型,Java 设计者为 String 提供了字符串常量池以提高其性能,那么字符串常量池的具体原理是什么,我们带着以下三个问题,去理解字符串常量池: 字符串常量池的设计意图是什么...字符串常量池在哪里? 如何操作字符串常量池?...字符串常量池的设计思想 字符串的分配,和其他的对象分配一样,耗费高昂的时间与空间代价,作为最基础的数据类型,大量频繁的创建字符串,极大程度地影响程序的性能 JVM为了提高性能和减少内存开销,在实例化字符串常量的时候进行了一些优化...为字符串开辟一个字符串常量池,类似于缓存区 创建字符串常量时,首先坚持字符串常量池是否存在该字符串 存在该字符串,返回引用实例,不存在,实例化该字符串并放入池中 实现的基础...实现该优化的基础是因为字符串是不可变的,可以不用担心数据冲突进行共享 运行时实例创建的全局字符串常量池中有一个表,总是为池中每个唯一的字符串对象维护一个引用,这就意味着它们一直引用着字符串常量池中的对象

    72010

    Jvm常量池、运行时常量池、字符串常量池理解

    字符串常量池(string pool) 字符串常量池里的内容是在类加载完成,经过验证,准备阶段之后在堆中生成字符串对象实例,然后将该字符串对象实例的引用值存到string pool中(记住:string...当字符串常量池中的存储比较多的字符串时,会导致hash冲突,从而每个节点形成长长的链表,导致性能下降。所以在使用字符串常量池时,一定要控制容量。...可以看出s3和s5都是对#4常量池的引用,为true的原因是jvm存在编译期优化的机制,在编译期(javac *.java时)会将可以拼接的字符串常量帮你自动拼接了,由于字符串常量池中已经存在了,因此会让...s3=s6输出true 简单介绍intern方法,可以使用intern方法,主动将串池中还没有的字符串对象放入字符串常量池 通过intern方法主动将s4的字符串放入了字符串常量池,将这个字符串对象尝试放入串池...若常量池中不存在等值的字符串,JVM就会在常量池中创建一个等值的字符串,然后返回该字符串的引用 所以s3和s6的指向地址并不相同,所以会返回false

    1.6K30

    字符串常量池概述

    字符串常量池概述 常量池表(Constant_Pool table) Class文件中存储所有常量(包括字符串)的table。...这部分内容(绝大部分)是随着JVM运行时候,从常量池转化而来,每个Class对应一个运行时常量池。 上一句中说绝大部分是因为:除了 Class中常量池内容,还可能包括动态生成并加入这里的内容。...字符串常量池(String Pool) 字符串常量池与运行时常量池不是一个概念: String Pool 是JVM 实例全局共享的全局只有一个,而Runtime Constant Pool 每个类都有一个...字符串池在JDK 1.7 之后存在于Heap 堆中,旧版存在于方法区中 【亨元模式】 其实字符串常量池这个问题涉及到一个设计模式,叫“享元模式”,顾名思义 – – – > 共享元素模式 也就是说:一个系统中如果有多处用到了相同的一个元素...Java中String部分就是根据享元模式设计的,而那个存储元素的地方就叫做“字符串常量池 – String Pool” 【详细分析】 首先, 10 和 “hello” 会在经过javac(或者其他编译器

    33330

    常量池之字符串常量池String.intern()

    执行intern()方法时,若常量池中不存在等值的字符串,JVM就会在常量池中 创建一个等值的字符串,然后返回该字符串的引用。 2. “”(引号)引起来的内容(字面量)。     ...引号引起来的字符串,首先从常量池中查找是否存在此字符串,如果不存在则在常量池中添加此字符串对象,然后引用此字符串对象。如果存在,则直接引用此字符串。...通过调用intern()方法,会在常量池中生成一个相同字符串的对象 “”内的字符串都会添加到常量池中,相当于引用的方法区中的字符串对象。...“”内的字符串实例引用会添加到常量池中(前提:常量池中没有相同内容的字符串),如果常量池中存在,则引用常量池中的对象(防止重复创建对象)。...方法名meme就会以字符串的方式加入到字符串常量池中,所以会感觉常量池中会内置很多字符串常量

    1.1K70

    运行时常量池与字符串常量池_常量池是什么

    2)运行时常量池存在什么地方? 3)取消永久代后,方法区的实现? 4)字符串常量池和运行时常量池究竟去了哪里? 4)元空间是什么? 5)关于为什么移除永久代?...话虽如此,但是关于字符串常量池和运行时常量池的模棱两可的说法一直都是争论不休的。 1)方法区包含哪些内容?...一些特殊方法 这里虽然没有说明“字符串常量池”,但是它也是方法区的一部分。...注意这里的剩余内容:说明原来移除从永久代移出的字符串常量池,静态常量,在更换了方法区实现后,并没有顺势进入到元空间,那么它们到哪里去了呢?...4)字符串常量池和运行时常量池究竟去了哪里?

    51520

    什么是字符串常量池_常量池中的字符串是对象吗

    只存放字符串引用 字符串常量池(String pool/String table) 字符串常量池又称为:字符串池,全局字符串池,英文也叫String Pool。...堆里边的字符串常量池存放的是字符串的引用或者字符串(两者都有) 比如new String(“test”)就会先在常量池中检查是否存在,不存在则在常量池中创建,然后堆中创建其引用。...常量池和字符串常量池的版本变化 在JDK1.7之前运行时常量池逻辑包含字符串常量池存放在方法区, 此时hotspot虚拟机对方法区的实现为永久代 在JDK1.7 字符串常量池、静态变量等被从方法区拿到了堆中...String两种创建方式 方式一(str值和字符串常量池中字面量地址相等) String str = "abc" 检查字符串常量池是否存在该字符串,存在则不创建并且返回该字符串的引用 不存在则在字符串常量池中创建该字符串常量并返回其常量池中地址...② jdk 1.7及以后:直接将堆中(不是字符串常量池中)该字符串的地址复制到字符串常量池中,这样字符串常量池就有了该字符串的地址引用,也可以说此时字符串常量池中的字符串只是一个对 堆中字符串对象的引用

    47340

    Java中的常量池【Class常量池、运行时常量池、字符串常量池】

    在解析阶段,会把符号引用替换为直接引用,解析的过程会去查询字符串常量池,也就是StringTable,以保证运行时常量池所引用的字符串字符串常量池中是一致的。...字符串常量字符串常量池在Java内存区域的哪个位置? 在JDK6.0及之前的版本,字符串常量池是放在Perm Gen区(也就是方法区)中; 在JDK7.0版本,字符串常量被移到了堆中。...字符串常量池是什么?...在之前版本中,里放的都是字符串常量 在中,由于发生了改变,因此中也可以存放放置在堆内的字符串对象的引用。...⚠️字符串常量池中的字符串只存在一份,且被所有线程共享 ⚠️全局字符串池里的内容是在类加载完成,经过验证、准备阶段之后在堆中生成字符串对象实例,然后将该字符串对象实例的引用值存到中;中存的是引用值而不是具体的实例对象

    1.6K20
    领券