下面来自jdk中src/java/lang下的String类的equals方法源码,反斜线//后面的部分为个人注释
public boolean equals(Object anObject) {
if (this == anObject) {
return true; //如果形参对象和当前对象引用相同地址,则认为他们相等,返回true
}
if (anObject instanceof String) {
String anotherString = (String)anObject; //如果是,强制类型转化为String类
int n = count; //将当前String对象的长度赋值给变量n
if (n == anotherString.count) { //判断当前String对象的长度与形参对象的长度是否相等,如果不等返回false
char v1[] = value; //将当前String对象的字符串的char[]
char v2[] = anotherString.value; //同上
int i = offset; //记录开始位置
int j = anotherString.offset; //同上
while (n-- != 0) { //逐个比较两字符数组的各元素是否相同,若存在不同,返回false
if (v1[i++] != v2[j++])
return false;
} return true; //比较完毕后发现全部相同,返回true
}
} return false; //如果所传对象不满足前两个if语句,则返回false
}
上面用到了几个变量,分别是count,value和offset,这几个成员变量在String 类的开始处进行了声明,如下
public final class String
implements java.io.Serializable, Comparable<String>, CharSequence
{
/** The value is used for character storage. */
private final char value[];
/** The offset is the first index of the storage that is used. */
private final int offset;
/** The count is the number of characters in the String. */
private final int count;
... ...
通过本例加深了自己的两点理解:
1. String类型对象不可变,通过其count,value,offset等成员变量的final修饰符可知。
2. 一个对象objA(类为Aclass),假设其存在private类型的成员变量f,private类型的变量在一般情况是不允许按照下面方式调用的:
例:objA.f
但如果此对象objA在另一个Aclass实例对象中被引用,则可以按照上述方式使用,所以equals方法中才有 anotherString.count 等类似语句。