Skip to main content

Java Interview Question: Difference Between == and equals() in Java (With Examples)

 🔹 Introduction

Understanding the difference between == and equals() is one of the most fundamental Java interview questions.

👉 Interviewers ask this to check your understanding of:

  • Memory
  • Object comparison
  • String handling

🔹 What is == in Java?

== is used to compare memory references (addresses).

👉 It checks:

  • Whether two variables point to the same object

🔹 Example Using ==

public class Test {
public static void main(String[] args) {
String a = new String("hello");
String b = new String("hello");

System.out.println(a == b);
}
}

🔹 Output

false

👉 Because both objects are stored in different memory locations


🔹 What is equals() in Java?

equals() is used to compare actual content (values).


🔹 Example Using equals()

public class Test {
public static void main(String[] args) {
String a = new String("hello");
String b = new String("hello");

System.out.println(a.equals(b));
}
}

🔹 Output

true

👉 Because values are the same


🔍 Important Interview Scenario

String x = "java";
String y = "java";

System.out.println(x == y);

🔹 Output

true

👉 Why?

Because of String Constant Pool
Both variables point to same memory


⚡ Key Differences

Feature==equals()
Comparison   Memory reference        Content/value
Used for               Primitives + Objects        Objects only
Overridable   No        Yes

🔹 When to Use What?

✔ Use ==

  • For primitive types
  • For reference comparison

✔ Use equals()

  • For comparing object values

🔹 Common Mistake

❌ Using == for String comparison
👉 Leads to wrong results


🔹 Time Complexity

  • O(1) for ==
  • O(n) for equals() (depends on object)

🔹 Key Takeaways

== → compares memory
equals() → compares value
✔ String pool affects behavior
✔ Very frequently asked interview question


🔹 Conclusion

Understanding == vs equals() is essential for writing correct Java programs and performing well in interviews.

🔗 Also Read


Comments

Popular posts from this blog

Top Java Interview Question: First Non-Repeating Character in a String

  🔹 Introduction Java interviews often include string-based questions. One of the most commonly asked questions is: 👉 Find the first non-repeating character in a string. In this article, we will solve it step by step in a simple and easy-to-understand way. 🔹 Problem Statement Given a string, find the first character that does not repeat. Example: Input: aabbcde Output: c 🔹 Approach To solve this problem efficiently: Count frequency of each character Maintain insertion order Traverse again to find the first character with frequency = 1 👉 We use LinkedHashMap because: It maintains insertion order Helps us find the first non-repeating character 🔹 Java Code import java . util . *; public class FirstNonRepeating { public static void main ( String [] args ) { String str = "aabbcde" ; Map < Character , Integer > map = new LinkedHashMap <>(); // Count frequency for ( char ch : str . to...

Java Interview Question: Separate Even and Odd Numbers Using Streams (With Examples)

  🔹 Introduction Separating even and odd numbers is a common Java interview question. It helps test your understanding of Java Streams, filtering, and partitioning . 👉 In this article, we will solve this using: Traditional approach Java Streams (modern approach) 🔹 Problem Statement Given a list of integers, separate even and odd numbers. Example: Input: [1, 2, 3, 4, 5, 6] Output: Even: [2, 4, 6], Odd: [1, 3, 5] 🔹 Approach 1: Using Loop (Basic) 💡 Explanation Traverse list Check number % 2 Store in separate lists 👨‍💻 Java Code import java . util . *; public class EvenOdd { public static void main ( String [] args ) { List < Integer > list = Arrays . asList ( 1 , 2 , 3 , 4 , 5 , 6 ); List < Integer > even = new ArrayList <>(); List < Integer > odd = new ArrayList <>(); for ( int num : list ) { if ( num % 2 == 0 ) { even . add ( num )...

Java Interview Question: Check if a String is a Palindrome

 🔹 Introduction String problems are very common in Java interviews. One of the easiest yet frequently asked questions is: 👉 Check whether a given string is a palindrome. Let’s understand how to solve it step by step. 🔹 Problem Statement A string is called a palindrome if it reads the same forward and backward. Example: Input: madam Output: Palindrome Input: hello Output: Not a Palindrome 🔹 Approach 1: Using Two Pointers (Best Method) Start one pointer from the beginning Start another pointer from the end Compare characters If all match → Palindrome 🔹 Java Code (Two Pointer Approach) public class PalindromeCheck { public static void main ( String [] args ) { String str = "madam" ; int left = 0 ; int right = str . length () - 1 ; boolean isPalindrome = true ; while ( left < right ) { if ( str . charAt ( left ) != str . charAt ( right )) { isPalindr...