原帖:
http://www.haohaoblog.com/?p=961
自己添加整理备用
public class StringTest {
public static void main(String[] args) {
String a = new String();
String a1 = new String("");
System.out.println(a == a1);// false
System.out.println(a.hashCode() == a1.hashCode());// true
System.out.println(a.equals(a1));// true
// 说明两者的哈希码是相同的,但是a==a1却是false,原因是两者在堆中的地址不一样,new出来
// 的对象,放在堆中,而==是比较对象的地址是否一样
/**
* 在Java中,哈希码代表了对象的一种特征,例如我们判断某两个字符串是否==,如果其哈希码相
* 等,则这两个字符串是相等的。
* 其次,哈希码是一种数据结构的算法。常见的哈希码的算法有:
* 1:Object类的hashCode
* 返回对象的内存地址经过处理后的结构,由于每个对象的内存地址都不一样,所以哈希码也不一
* 样。
* Object的 equals方法return (this == obj),也就是==
* 2:String类的hashCode
* 根据String类包含的字符串的内容,根据一种特殊算法返回哈希码,只要字符串内容相同,返回
* 的哈希码也相同。
* String的 equals方法值相同返回true
* 3:Integer类,返回的哈希码就是Integer对象里所包含的那个整数的数值
* 例如Integer i1=new Integer(100),i1.hashCode的值就是100 。
* 由此可见,2个一样大小的Integer对象,返回的哈希码也一样。
*/
String b=new String ("123");
String b1=new String("123");
System.out.println(b==b1);//false
System.out.println(b.hashCode()==b1.hashCode());// true
// 这里说明一点对象的引用是放在栈stack内容中的,引用是一个指向,并不是一个对象,另外对象
// 是放在堆heap内存中的
/**
* 这里说明下,c是对象引用,c1,c2也是对象引用,都放在栈中,但是不同的是,他们指向的位置,
* 前者指向的是堆内存,当new一个对象时,CPU就会为其开辟一个空间,然后再新建一个
* 字符串"123",而这个字符串不是放在String常量池中的,所谓String常量池是一个区域,
* 这个区域存放的是所有字符串常量,这些字符串常量都不重复,它们供程序调用,例如下面一段
* 程序,c1,c2都是指向常量池的,由于常量池的内容不能重复所以它们指向 的是同一个地方的同
* 一个对象,但是new出来存放的字符串常量,则不是放在这个区域中,所以new String("123")
* 是创建了两个对象。另外一点String常量池中的 对象是不会被JVM回收的,而堆中的对象则会被
* 垃圾回收站回收
*/
String c=new String("123");
String c1="123";
String c2="123";
System.out.println(c1==c2);// true
System.out.println(c==c1);// false
System.out.println(c.hashCode()==c1.hashCode());// true
System.out.println(c.equals(c1));// true
/**
* 针对下面的代码,来做个说明,其实d和d1是等同的,但是这个过程却是不同,虽然结果一样,那
* 么过程如何不同呢?d是创建了三个字符串常量,然后将这些拼接起来,生成另一个字符串常量,
* 这个过程生成了四个字符串对象。另外,顺带说下,String类型不是原始数据类型,它是一个不可
* 变类,但由于它的机制决定了它的多重角色性。
*/
String d = "1" + "2" + "3";
String d1 = "123";
String d2 = new String("1" + "2" + "3");
String d3 = new String("1" + "2" + "3");
System.out.println(d.equals(d1));// true
System.out.println(d == d1);// true
System.out.println(d.hashCode() == d1.hashCode());// true
System.out.println(d2.hashCode() == d3.hashCode());// true
}
}
分享到:
相关推荐
各种字符串相似度和距离算法的实现:Levenshtein,Jaro-winkler,n-Gram,Q-Gram,Jaccard索引,最长公共子序列编辑距离,余弦相似度......
String3.1-java堆和栈---马克-to-win java视频 马克Java社区 马克towin
86.java中String对象的特点.zip86.java中String对象的特点.zip86.java中String对象的特点.zip86.java中String对象的特点.zip86.java中String对象的特点.zip86.java中String对象的特点.zip86.java中String对象的特点....
【Java面试题】对String常量池的理解
java-string-similarity, 各种字符串相似性和距离算法 java-string-similarity 实现不同字符串相似度和距离度量的库。 目前已经实现了许多算法( 包括Levenshtein编辑距离和 sibblings,jaro winkler,最长公共子序列...
java String 使用详解,看完对String 的用法完全掌握
Educoder题目:Java面向对象 - String类答案解析
similarity cosine ontology
Java中颜色的String和Color对象之间的互相转换
深入了解java中的String-字符串(csdn)————程序
java中String类型转换方法.pdf
String 马克-to-win java视频 字符串的详细描述介绍
String 马克-to-win java视频 字符串的具体描述介绍
例子在这个简单的例子中,我们想要计算McDonalds和MacMahons之间的相似度得分。 我们正在选择算法。 SimilarityStrategy strategy = new JaroWinklerStrategy ();String target = " McDonalds " ;String source = " ...
String 马克-to-win java视频 字符串的详细描述介绍
java文档String和StringTokenizer 马克-to-win java视频 字符串解析器
java string用法详解
83.java中String构造方法.zip83.java中String构造方法.zip83.java中String构造方法.zip83.java中String构造方法.zip83.java中String构造方法.zip83.java中String构造方法.zip83.java中String构造方法.zip83.java中...
85.java中String构造方法.zip85.java中String构造方法.zip85.java中String构造方法.zip85.java中String构造方法.zip85.java中String构造方法.zip85.java中String构造方法.zip85.java中String构造方法.zip85.java中...
C++ String 详解 C++ String 详解 C++ String 详解 C++ String 详解 C++ String 详解