"일꾼이 일을 잘하려면 먼저 도구를 갈고 닦아야 한다." - 공자, 『논어』.
첫 장 > 프로그램 작성 > Java의 정수 상수 풀이 127 위에서 다르게 동작하는 이유는 무엇입니까?

Java의 정수 상수 풀이 127 위에서 다르게 동작하는 이유는 무엇입니까?

2024년 12월 22일에 게시됨
검색:264

Why Does Java's Integer Constant Pool Behave Differently Above 127?

질문: 127에서 Java 정수 상수 풀 동작의 차이

소개:

The 정수 상수 풀은 성능을 향상시키기 위해 공통 정수 값의 캐싱을 최적화하는 Java의 메커니즘입니다. 그러나 이 풀의 동작은 127에서 변화를 보여 개발자들 사이에 혼란을 야기합니다.

동작 이해:

-128에서 127 사이의 정수에 대해 , Java는 동일한 상수를 참조하는 변수에 대해 동일한 참조를 보장합니다.

Integer i1 = 127;
Integer i2 = 127;
System.out.println(i1 == i2); // True

이러한 값은 상수 풀에 캐시되어 있기 때문입니다.

Divergence at 128:

단, 정수 값이 다음을 초과하는 경우 127에서는 동작이 변경됩니다.

Integer i1 = 128;
Integer i2 = 128;
System.out.println(i1 == i2); // False

이는 구현 최적화 때문입니다. JLS는 해당 범위를 넘어서는 최대 127개의 값에 대한 캐싱을 보장하지만 구현에서는 값을 다르게 캐시하거나 전혀 캐시하지 않도록 선택할 수도 있습니다.

추가 고려 사항:

심지어 보장된 범위(-128~127) 내에서는 캐싱 동작이 항상 신뢰할 수 있는 것은 아닙니다. 예를 들어 new Integer()를 사용하면 상수 풀을 우회하고 새 참조를 만들 수 있습니다.

Integer i1 = new Integer(127);
Integer i2 = new Integer(127);
System.out.println(i1 == i2); // False

결론:

127에서 정수 상수 풀의 동작은 구현 최적화와 JLS에서 정의한 보장 범위에서 비롯됩니다. 개발자는 예상치 못한 결과를 방지하기 위해 이러한 동작 변화를 알고 있어야 합니다.

최신 튜토리얼 더>

부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.

Copyright© 2022 湘ICP备2022001581号-3