File APIs for Java Developers
Manipulate DOC, XLS, PPT, PDF and many others from your application.
The moose likes Programmer Certification (SCJP/OCPJP) and the fly likes equal() and hashcode().. Big Moose Saloon
  Search | Java FAQ | Recent Topics | Flagged Topics | Hot Topics | Zero Replies
Register / Login
JavaRanch » Java Forums » Certification » Programmer Certification (SCJP/OCPJP)
Bookmark "equal() and hashcode().." Watch "equal() and hashcode().." New topic

equal() and hashcode()..

Preethi Dev
Ranch Hand

Joined: Sep 07, 2008
Posts: 265
I got it from Master Exam.
16.System.out.println("x=" + x);

if the output is "x=1111", which of the following will always be true?

Answer given: x2.equals(x1)==true
I think this answer violates the contract.the correct answer would be x5.hashcode()==x6.hascode().
other than "x2.equals(x1)" the rest are coming under "can be true" so not suitable for the question asked.

please do correct me if i am wrong.

M Srilatha
Ranch Hand

Joined: Aug 27, 2008
Posts: 137

I guess it would be better if you can give all the options.
Then it would be easier!

Thanks,<br />Srilatha M
Ankit Garg

Joined: Aug 03, 2008
Posts: 9462

Under the given circumstances, Arun is right. Since the hashCodes don't match, so the objects can never be equal...

SCJP 6 | SCWCD 5 | Javaranch SCJP FAQ | SCWCD Links
subhasish nag
Ranch Hand

Joined: Apr 25, 2008
Posts: 101
Hi Pritha,
you are right.

Thanks,<br />Subhasish
geeta vemula
Ranch Hand

Joined: Jul 18, 2008
Posts: 208
Hi preetha,

yes the answer is x5.hashcode==x6.hashcode and its given correct in master exam.
patrick avery
Ranch Hand

Joined: Sep 12, 2008
Posts: 46
Like M Srilatha, I would also like to see all of the original choices for the answers to the question.

There is a good Mock exam (7 questions) on the hashCodes and equals contract for Inquisition (

I find that there are really only 2 rules to remmber, i.e.
Rule 1 if x1.equals(x2)==true then x1.hashCode()==x2.hashCode()
Rule 2 if x1.hashCode()!=x2.hashCode() then x1.equals(x2)==false

because if x1.equals(x2)==false
then nothing can be deduced about hashCode()
and if x1.hashcode()==x2.hascode()
then nothing can be deduced about equals()

Please someone correct me if I have incorrectly oversimplified it.

Using these rules on the problem as given,

line 12,
12. if(x1.hashcode()!=x2.hashcode())x=x+1;
easily disproves the answer:

and line 14,
14. if(x5.equals(x6)==true)x=x+100;
easily proves the answer:

SCJA 96%
SCJP 6 88%
skipping SCJD to work on passing SCWCD
Fabio Nascimento

Joined: Nov 16, 2008
Posts: 16
The rules to remember are:

If x.equals(y)==true then x.hashCode()==y.hashCode() MUST be true;
If x.equals(y)==false then x.hashCode()==u.hashCode() MIGHT be true;

And these rules are applied on Collections that uses Hash Codes for fast searching, because they first search the bucket (hashCode) before search the object (equals), otherwise equals() have nothing to do with hashCode().

For instance:

They will be equals even with differente hashCodes, but they will not be found in a collection that uses hash codes for fast searching using its own implemented methods.
[ December 05, 2008: Message edited by: Fabio Nascimento ]
Asanka Vithanage
Ranch Hand

Joined: Oct 24, 2008
Posts: 59
hay ranchers,

this is not a big problem if you know little pure mathematics

If A implies B

we can say (Not)B implies (Not)A

thats all to remember

we can think A as equals() method return true and
B as two hashcode values are same

hopes you can understand

SCJP 1.5 (94%)
I agree. Here's the link:
subject: equal() and hashcode()..
It's not a secret anymore!