JAVA에서 문자열 상수 풀과 버퍼 풀의 역할은 무엇입니까?
1 상수 풀
상수 풀은 두 가지 종류로 나뉘는데, 하나는 .class 파일에 있는 정적 상수 풀이고, 다른 하나는 .class 파일에 있는 정적 상수 풀입니다. 런타임 상수 풀에 로드됩니다.
1.1 정적 상수 풀
. .class 파일의 상수 풀은 배열로 간주될 수 있습니다. 일부 상수는 바이트코드 명령어에 사용되어야 할 때 배열의 인덱스입니다. 이용됩니다. 꼭 방문해 보세요.
아래 코드를 보세요:
String m = "hellohellohellohellohello"; String n = "hellohellohellohellohello";
바이트코드에서는 다음과 같은 형태입니다:
// 常量池: #1 hellohellohellohellohello #2 ... ... ---------------------------- String m = #1; String n = #1;
물론 이것은 단순화된 버전일 뿐이고 실제로는 더 복잡합니다(실제 버전은 다음에서 찾을 수 있습니다). 기사 마지막 부분의 참조 섹션에 게시된 답변은 현재 단순화된 버전만 고려할 수 있습니다.)
여기에 저장된 문자열 상수는 Java 문자열 객체가 아닌 단순한 UTF8로 인코딩된 바이트 시퀀스일 뿐입니다. txt 텍스트에 저장한 문자열과 마찬가지로 UTF8 형식을 사용하여 .class 파일을 엽니다. hellohellohellohello
를 구문 분석할 수 있습니다. hellohellohellohellohello
是可以被解析的:
1.2 运行时常量池
理解了静态的常量池之后,运行时常量池就很容易想明白了。简单来说,运行时常量池就是.class文件中的静态常量池在JVM中的运行时表示,每一个.class文件的静态常量池都会生成一个对应的运行时常量池。等到JVM在解释String m = #1
这条指令时,它可以去这个类的运行时常量池中查找#1的定义。
2 字符串池
字符串池是Java为了重用String
对象而设置的一个缓存池,Java1.7之前设置在方法区上,保存的是String对象;Java1.7之后设置在堆上,保存的是String
对象的引用,String
对象本身存在于堆上的其他位置。下文中以Java1.7之后的情况为标准。
继续上面的例子。当JVM在解释String m = #1时,它已经从运行时常量池拿到了相应的UTF8序列,接下来,它会在字符串池中寻找和这个UTF8序列对应的String对象,并把这个对象的引用赋值给m。你可能会好奇这个String被创建的时机,根据R大的这篇文章,在这条语句所在的类被加载时,如果字符串池中已经存在对应的对象了,那么就什么都不做,如果不存在,就会创建一个对应的String对象,并把其引用放入池中。
除了字符串池,Integer
、Long
等Wrapper类型也有自己的缓存池,比如Integer
会缓存从-128~127的Integer
对象,当使用字面量赋值或者Integer.valueOf()
1.2 런타임 상수 풀
정적 상수 풀, 런타임 상수 풀은 이해하기 쉽습니다. 간단히 말해서, 런타임 상수 풀은 JVM의 .class 파일에 있는 정적 상수 풀의 런타임 표현입니다. .class 파일의 각 정적 상수 풀은 해당 런타임 상수 풀을 생성합니다. JVM이String m = #1
명령을 해석할 때 이 클래스의 런타임 상수 풀로 이동하여 #1의 정의를 찾을 수 있습니다. 2 문자열 풀🎜🎜 문자열 풀은 String
개체를 재사용하기 위해 Java에서 설정한 캐시 풀입니다. Java1.7 이전에는 메서드 영역에 설정되고 Java1.7에 저장된 문자열 개체입니다. 그런 다음 힙에 설정되고 String
개체에 대한 참조를 보유합니다. String
개체 자체는 힙의 다른 곳에 존재합니다. 다음은 Java 1.7 이후의 상황을 기준으로 합니다. 🎜🎜위의 예를 계속 진행하세요. JVM이 String m = #1을 해석할 때 런타임 상수 풀에서 해당 UTF8 시퀀스를 얻었습니다. 그런 다음 문자열 풀에서 이 UTF8 시퀀스에 해당하는 String 개체를 찾고 개체의 참조를 추가합니다. m에게 할당되었습니다. 이 문자열이 생성되는 시점이 궁금할 수 있습니다. 이 R 기사에 따르면 이 문이 있는 클래스가 로드될 때 해당 개체가 문자열 풀에 이미 있으면 아무 작업도 수행되지 않습니다. 존재하지 않는 경우 해당 String 개체가 생성되고 해당 참조가 풀에 배치됩니다. 🎜🎜문자열 풀 외에도 Integer
및 Long
과 같은 래퍼 유형에도 자체 캐시 풀이 있습니다. 예를 들어 Integer
는 캐시합니다. -128~127 Integer
객체의 값, 리터럴 할당이나 Integer.valueOf()
사용 시 해당 객체가 풀에 존재하는 경우 풀에 있는 객체 풀이 있을 때만 반환됩니다. 새 객체가 없는 경우에만 힙에 생성됩니다. 🎜🎜그러나 이러한 Wrapper 풀은 스트링 풀과 달리 스트링 풀처럼 커지지 않습니다. 즉, 풀에 포함되는 개체 수가 고정되어 있고 정수 풀에는 -128~127만 있습니다. 🎜🎜기본형에 해당하는 버퍼 풀은 다음과 같습니다. 🎜boolean values true and false all byte values short values between -128 and 127 int values between -128 and 127 char in the range \u0000 to \u007F
위 내용은 JAVA에서 문자열 상수 풀과 버퍼 풀의 역할은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제









Java의 난수 생성기 안내. 여기서는 예제를 통해 Java의 함수와 예제를 통해 두 가지 다른 생성기에 대해 설명합니다.

자바의 암스트롱 번호 안내 여기에서는 일부 코드와 함께 Java의 Armstrong 번호에 대한 소개를 논의합니다.

Java의 Weka 가이드. 여기에서는 소개, weka java 사용 방법, 플랫폼 유형 및 장점을 예제와 함께 설명합니다.

Java의 Smith Number 가이드. 여기서는 정의, Java에서 스미스 번호를 확인하는 방법에 대해 논의합니다. 코드 구현의 예.

이 기사에서는 가장 많이 묻는 Java Spring 면접 질문과 자세한 답변을 보관했습니다. 그래야 면접에 합격할 수 있습니다.

Java 8은 스트림 API를 소개하여 데이터 컬렉션을 처리하는 강력하고 표현적인 방법을 제공합니다. 그러나 스트림을 사용할 때 일반적인 질문은 다음과 같은 것입니다. 기존 루프는 조기 중단 또는 반환을 허용하지만 스트림의 Foreach 메소드는이 방법을 직접 지원하지 않습니다. 이 기사는 이유를 설명하고 스트림 처리 시스템에서 조기 종료를 구현하기위한 대체 방법을 탐색합니다. 추가 읽기 : Java Stream API 개선 스트림 foreach를 이해하십시오 Foreach 메소드는 스트림의 각 요소에서 하나의 작업을 수행하는 터미널 작동입니다. 디자인 의도입니다
