1. 객체 생성
Java 프로그램의 직접 문자열 상수의 경우 JVM은 문자열 풀을 사용하여 저장합니다. 문자열 직접 상수가 처음으로 사용되면 JVM은 캐싱을 위해 이를 문자열 풀에 넣습니다. 일반적인 상황에서는 문자열 풀의 문자열 개체가 가비지 수집되지 않습니다. 프로그램이 문자열을 다시 사용해야 하는 경우 참조 변수는 새 문자열을 다시 생성하지 않고도 문자열의 기존 문자열을 직접 가리킬 수 있습니다. new 작업을 사용하여 생성된 문자열 개체는 문자열 풀의 개체를 가리키지 않지만 intern() 메서드를 사용하여 문자열 풀의 개체를 가리킬 수 있습니다.
public class StringDemo1 { public static void main(String[] args){ String str1 ="abc"; String str2 ="abc"; String str3 =new String("abc"); System.out.println(str1==str2);//true System.out.println(str1==str3);//false } }
FAQ
String str3 =new String("abc");
얼마나 많은 객체가 생성되었나요?
답변:
String str ="ab"+"cd";
두 개로 만들어진 개체는 몇 개입니까?
정답: 하나. "ab" 및 "cd"는 문자열 풀에 배치된 상수입니다. 따라서 하나의 abcd 문자열 풀만 생성되고 abcd 문자열이 문자열 풀에 저장됩니다.
public class StringDemo1 { public static void main(String[] args){ String str1 ="ab"; String str2 ="cd"; String str3 ="ab"+"cd";//创建对象并加入字符串池 String str4 =str1+str2; String str5 =str1+"cd"; System.out.println(str3==str4);//false System.out.println(str3==str5);//false } }
위 코드에서 볼 수 있듯이, 텍스트가 포함된 따옴표로 생성된 String 객체만 문자열 풀에 추가될 수 있습니다. 메서드를 사용하면 새 개체가 문자열 풀에 추가되지 않습니다.
하지만 주의가 필요한 상황이 있습니다.
public class StringDemo1 { private final static String str1 ="ab"; private final static String str2 ="cd"; public static void main(String[] args){ String str3 ="ab"+"cd";//创建对象并加入字符串池 String str4 =str1+str2; String str5 =str1+"cd"; System.out.println(str3==str4);//true System.out.println(str3==str5);//true } }
이게 왜일까요? 그 이유는 상수 때문입니다. 해당 값은 고정되어 있으므로 컴파일 타임에 결정될 수 있습니다.
위의 코드를 약간 변경하여 어떻게 되는지 확인해 보세요.
public class StringDemo1 { private final static String str1 ; private final static String str2; static{ str1="ab"; str2="cd"; } public static void main(String[] args){ String str3 ="ab"+"cd";//创建对象并加入字符串池 String str4 =str1+str2; String str5 =str1+"cd"; System.out.println(str3==str4);//false System.out.println(str3==str5);//false } }
str1과 str2는 상수로 정의되어 있지만 s의 값이 계산되기 전에는 언제 할당되고 어떤 값이 할당되는지는 변수이므로 속성은 다음과 같습니다. 및 변수는 동일합니다. 런타임에만 생성할 수 있습니다.
2. 문자열 방식
가져오기 방식
•int length()
•char charAt(int index) Position은 특정 문자를 가져옵니다.
•int indexOf(int ch)는 문자열에서 ch가 처음 나타나는 위치를 반환합니다.
•int indexOf(int ch,int fromIndex) fromIndex로 지정된 위치부터 시작하여 ch를 가져옵니다. 문자열에서 처음 나타나는 위치
•int indexOf(String str)
•int indexOf(String str,int fromIndex)
•int lastIndexOf(int ch)
메서드
•boolean contain(String str) 또 다른 판단 방법: if(str.index(str)!=-1)
•boolean startWith(String str)
•boolean endWith( String str)
•bolean isEmpty(String str)
•boolean equals(String str)
•boolean equalsIgnoreCase(String str);
변환 방법
•문자 배열을 문자열로 변환합니다.
생성자
1.String(char[] chs)
2.String(char[] chs,offset,count) 문자 변환 배열의 일부를 끈.
정적 메서드
1.static String copyValueOf(char[] chs)
2.static String copyValueOf(char[] chs,int offset,int count)
3.static String valueOf(char[] )
4.static String valueOf(char[] chs,int offset,int count)
•문자열을 문자 배열로 변환
char[] toCharArray
•문자 배열을 문자열로 변환
•문자열을 바이트 배열로 변환
byte[] toBytes
교체 방법
문자열 대체(olderStr,newStr)
잘라내기 방법
문자열 분할(regex)
하위 문자열 가져오기 [분류 편집]
String subString(begin)
String subString(begin,end)에는 머리는 포함되지만 꼬리는 포함되지 않습니다
문자열을 대문자와 소문자로 변환 Android(10)
String toUpperCase()
String toLowerCase()
문자열 양쪽 끝 공백 제거
String Trim()
두 문자열의 자연스러운 순서 수행
< 비교 🎜>int CompareTo(String str)3.문자열 연습1. 문자열 반전public class StringDemo2 { public static void main(String[] args){ String str = "avdkfasjks"; reverseMethod_1(str); } public static void reverseMethod_1(String str){ for(int i=str.length();i>0;i--){ System.out.print(str.charAt(i-1)); } } }
public class StringDemo2 { public static void main(String[] args){ String str1 = "avdkfasjks"; String str2 = "ewavdrtte"; System.out.println(commonMaxSubstring(str1, str2)); } public static String commonMaxSubstring(String str1,String str2){ int len = str1.length(); String str3 = null; outer: //i为子串的长度 for(int i = len;i>0;i--){ //j为子串的脚标 for(int j=0;j<len-i+1;j++){ str3=str1.substring(j,j+i); if(str2.contains(str3)) break outer; } } return str3; } }