问题标签 [string-pool]
For questions regarding programming in ECMAScript (JavaScript/JS) and its various dialects/implementations (excluding ActionScript). Note JavaScript is NOT the same as Java! Please include all relevant tags on your question; e.g., [node.js], [jquery], [json], [reactjs], [angular], [ember.js], [vue.js], [typescript], [svelte], etc.
java - Java - 选择字符串来存储加密的密码有什么问题?
我们在 java 中将密码存储为 char 数组,并找到这样做的充分理由。我遇到了一个面试问题,上面写着“如果密码被加密并且我们将其保存在 String 中,可以吗?或者为什么不呢? ”
我能想到的是加密和解密过程涉及某处的纯文本字符串对象,我们又回到了字符串中的相同问题纯文本密码。我对自己的回答不太相信,这可能是什么原因/理由。
java - 与 concat 一起使用时,字符串池的行为会有所不同吗?
如果我删除第 2 行并比较 s1==s2,它将返回 true。谁能解释一下 Line-2 之后字符串池中到底发生了什么?堆和常量池中的每一行发生了什么?
据我了解,s1 将在常量池中创建“HelloWorld”。但仍然 s1 == s2 是假的?
java - 调用 intern() 时从池中返回哪个 String 对象的引用
Java 语言规范指出
调用 intern 方法时,如果池中已经包含一个等于该 String 对象的字符串,由 equals(java.lang.Object) 方法确定,则返回池中的字符串
在以下代码片段中:
输出:
我首先将一个 String 对象添加到池中(将 String 文字分配给引用),然后使用 String 构造函数显式创建第二个对象。现在池中有两个相同的字符序列。
我想看看调用intern时会返回哪一个。由于类 String的hashCode方法被覆盖,我使用System.identityHashCode来准确查看哪两个 String 引用是相同的。
显然,intern返回了对使用字符串文字创建的对象的引用。为什么会这样?如果池中有多个相同的 String 对象,是否有关于返回哪个引用的规则?
java - 字符串池内部代码如何作为 StringConstantPool 被弃用?
您能否让我知道Stringpool实现背后的确切类,因为我想知道它是如何实现FlyWeightDesign 模式的
java - 如 String.intern() 方法的 Javadoc 中所述,字符串池最初是否真的为空?
下面是 String.intern() 方法的 Javadoc 注释:
*返回字符串对象的规范表示。
字符串池,最初为空,由 String 类私下维护。
当调用 intern 方法时,如果池中已经包含一个等于该 String 对象的字符串,该字符串由 equals(Object) 方法确定,则返回池中的字符串。否则,将此 String 对象添加到池中并返回对该 String 对象的引用。
由此可见,对于任何两个字符串 s 和 t,当且仅当 s.equals(t) 为真时,s.intern() == t.intern() 才为真。
所有文字字符串和字符串值的常量表达式都是实习的。字符串文字在 Java™ 语言规范的第 3.10.5 节中定义。”
但我认为从 jdk-8u102 开始发生了一些变化。
检查以下示例:
如果您在 JDK 7u80(JDK 7 的最新稳定版本)和 JDK 8 到 8u101 中运行上述程序,则输出为:
true
但是,如果您在 JDK 8u102 及 JDK 9 和 JDK 10 中运行上述程序,则输出为:
false
为什么 intern() 方法从 JDK 8u102 开始表现不同?
我检查了发行说明和 Javadoc 注释,但找不到任何与 JDK 8u102 中的 intern() 方法相关的更改。
我检查了博客和其他网站,但没有运气。
但是当我尝试使用其他字符串时,输出没有变化:
上面的程序在 JDK 7、JDK 8、JDK 9 和 JDK 10 中总是打印true 。
只有在加载 Test1 类之前字符串池表引用了“Java”时,此行为才可能发生。
s1 引用 HEAP 上的字符串对象“Java”,s1.intern() 返回字符串池对象的引用(因为字符串池已经引用了“Java”)。
这就是 s1 == s2 返回 false 的原因。
但是当加载 Test2 类时,字符串池表不会引用“Udayan”。
s3 引用 HEAP 上的字符串对象“Udayan”,s3.intern() 将 s3 引用的字符串对象添加到字符串池并返回相同的引用。这意味着 s3 和 s4 指的是同一个对象。
这就是 s3 == s4 返回 true 的原因。
如果我的观察是正确的,那么这意味着字符串池最初不是空的。
字符串池最初包含“Java”、“java”、“Oracle”和其他字符串对象。
任何人都可以确认这一点吗?
java - java中的String Pool在内部使用什么数据结构?
我了解java中String Pool的用例,但我想知道在实现String Pool时使用的是什么数据结构。我的意思是当我们谈论字符串的实习时,JVM 需要在整个字符串池中搜索任何现有的字符串。那么这个过程是如何优化的呢?
python - 删除字符串池
我想20MB
每 3 秒生成一个大字符串 (+)。现在我的问题是我的字符串池越来越大,我没有RAM
。
任何人都知道如何手动删除字符串池?
谢谢。
java - Java Compiler 如何在编译时处理修改后的字符串
对于字符串文字,实习应该隐式发生。那么为什么 a 和 c 被视为两个不同的字符串?a 和 c 会指向字符串池中的相同内存引用吗?a 和 c 返回的哈希码相同,但 a==c 返回 false。有人可以解释为什么返回的值是假的。
java - Eclipse 字符串缓存错误,== 没有按预期工作
我有一个简单的应用程序,它有一个比较两个文字字符串的 main 方法:
当我在Eclipse中运行这个程序时,我得到false
了结果。但是当我通过命令行编译和运行这个程序时,我得到了true
。
结果应该true
适用于两者。为什么 Eclipse 会返回false
?
我已经使用 JDK 7 和 8 对其进行了测试。
请注意,我知道与==
比较身份的比较。
对于这两个变量, JLS 都需要"a"
从内部字符串缓存中出来。
但是,如果我从 Eclipse 运行它,我会得到false
比较,因此尽管 JLS 要求它们相同,但两个实例似乎不同。
因此,请参阅JLS§3.10.5 字符串文字:
此外,字符串字面量总是引用 String 类的同一个实例。这是因为字符串文字——或者更一般地说,作为常量表达式值的字符串(第15.28 节)——是“ interned ”,以便使用 方法共享唯一实例。
String.intern