How Does Declaring Strings as `final` Affect `==` Comparison in Java?
Understanding the Impact of Final on String Comparison in Java
In Java, the equality of strings is typically determined using the equals() method. However, the == operator can also be used for comparison, but its behavior differs when dealing with final strings.
When a String variable is declared final and initialized with a compile-time constant expression, it becomes a constant variable and its value is inlined by the compiler. This inlining leads to a significant difference in the comparison using ==.
Consider the following code example:
String str1="str"; String str2="ing"; String concat=str1+str2; System.out.println(concat=="string"); // false
The comparison in this example returns false because concat is a new String object created at runtime by concatenating str1 and str2.
Now, let's modify the code by declaring str1 and str2 as final:
final String str1="str"; final String str2="ing"; String concat=str1+str2; System.out.println(concat=="string"); // true
In this case, the comparison returns true. This is because when str1 and str2 are declared final, they become constant variables and are inlined at compile time. The concatenation of the two strings is also computed at compile time, resulting in a constant String object with the value "string."
The difference arises because string literals are interned in Java. Interning involves storing a unique instance of a String object in a pool for future reference. When a final String is inlined at compile time and compared with a string literal, the references to the String objects in the intern pool are directly compared, resulting in true.
In summary, when dealing with final strings declared with compile-time constant expressions, the comparison using == will return true if the concatenated value is equal to the other string literal, due to the interning of String objects at compile time.
The above is the detailed content of How Does Declaring Strings as `final` Affect `==` Comparison in Java?. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

Troubleshooting and solutions to the company's security software that causes some applications to not function properly. Many companies will deploy security software in order to ensure internal network security. ...

Field mapping processing in system docking often encounters a difficult problem when performing system docking: how to effectively map the interface fields of system A...

When using MyBatis-Plus or other ORM frameworks for database operations, it is often necessary to construct query conditions based on the attribute name of the entity class. If you manually every time...

Solutions to convert names to numbers to implement sorting In many application scenarios, users may need to sort in groups, especially in one...

Start Spring using IntelliJIDEAUltimate version...

Conversion of Java Objects and Arrays: In-depth discussion of the risks and correct methods of cast type conversion Many Java beginners will encounter the conversion of an object into an array...

Detailed explanation of the design of SKU and SPU tables on e-commerce platforms This article will discuss the database design issues of SKU and SPU in e-commerce platforms, especially how to deal with user-defined sales...

When using TKMyBatis for database queries, how to gracefully get entity class variable names to build query conditions is a common problem. This article will pin...
