以下のエディターは、JavaStrings に関する高度な記事 (必読の記事) をお届けします。編集者はこれが非常に良いものだと思ったので、皆さんの参考として今から共有します。エディターをフォローして、一緒に見てみましょう
前書き
文字列操作に最もよく使用される 3 つのクラス、つまり String、StringBuilder、および StringBuffer があります。これらの 3 つのクラスについては、以下で詳しく説明します。 ..
String
これは文字列の最も基本的なクラスです。ここでは詳しくは紹介しません。
new String(String str)new String(StringBuilder str)
new String(StringBuffer str)new String(byte[] bys,String charsetName) 指定されたcharset
を使用してデコードされ、 new 指定されたバイト部分配列からの文字列。str charAt(int index) 指定されたインデックスの文字を返しますString concat(String str) 指定された文字列 str をこの文字列の末尾に連結し、接続が完了した後の文字を返しますしたがって、この文字列に指定された char 値のシーケンスが含まれているかどうかを判断するには、有効にするために受け入れられる必要があります。CharSequence は、パラメーター (String, StringBuffer, StringBuild)
static String copyValueOf(char[] c)文字配列
を文字列に変換して返します static String copyValueOf(char[] c,int off,int count) インターセプトした文字配列を次のように変換します文字列を返し、off はインターセプトを開始する添字、count はインターセプトの数ですboolean endWith(String s) で文字列が s で終わるかどうかを判断しますint indexOf (char c) return 文字列内で文字 c が最初に出現するインデックスint indexOf(char c,int fromIndex) 指定されたインデックスから検索を開始し、最初に出現するインデックスを見つけますint indexOf(String str)指定された部分文字列を返します。この文字列内で最初に出現する部分のインデックス。 intindexOf(String str,int fromIndex) 指定されたインデックスから開始して、この文字列内で指定された部分文字列が最初に出現するインデックスを返します。 boolean isEmpty()int length()booleanmatches(String regex)正規表現に一致するかどうか
trim() 先頭と末尾の空白を無視して、文字列のコピーを返します。 String substring(int beginIndex) は、この文字列の部分文字列である新しい文字列を返します。String substring(int beginIndex, int endIndex) は、この文字列の部分文字列である新しい文字列を返します。
String toUpperCase() デフォルトのロケールの規則を使用して、この String 内のすべての文字を大文字に変換します。 String[] split(String regex) 指定された正規表現の一致に基づいてこの文字列を分割します。 String[] split(String regex, int limit) 指定された正規表現との一致に基づいてこの文字列を分割します。 char[] toCharArray() この文字列を新しい文字配列に変換します。 byte[] getBytes(Charset charset) は、指定された charset を使用してこの String をバイト シーケンスにエンコードし、結果を新しいバイト配列に格納します 注 new String(byte[] bys Above , String charsetName ) この 構築メソッド は非常に重要です (byte[] getBytes(Charset charset) と組み合わせて使用されます)。コードは次のとおりです。 /*
* InputStreamReader实现了将字节流FileInputStream转换为字符流,然后使用转换来的字节流创建高效流,从而实现高效的读写
*/
/*
* 编码集(我的eclipse编辑器默认的是utf-8
* 下面将中文字符串的编码集变为GBK写入a.txt文件,因为a.txt默认的是utf-8的因此这里在文件中显示的是乱码
* 然后我们读出来的还是GBK的,因为我们写入的是GBK编码集的,但是我的eclipse是utf-8的编码集,因此在控制台上输出的还是乱码
* new String(byte[] bys,String
* charsetName)使用这个构造方法将byte数组改变编码集并且转换为utf-8格式的,那么这次在控制台上输出的就不乱码了
*/
// 将GBK格式的中文写入a.txt文件
File file = new File("src/a.txt");
FileOutputStream fileOutputStream = new FileOutputStream(file);
String str = "中";
byte[] by = str.getBytes("GBK"); // 将字符串改为GBK编码集
fileOutputStream.write(by);
fileOutputStream.close();
//从a.txt文件中读取中文
FileInputStream fileInputStream = new FileInputStream(file);
int len;
byte[] bys = new byte[4];
while ((len = fileInputStream.read(bys)) != -1) {
System.out.println(new String(bys, "GBK"));
}
fileInputStream.close();
スレッドセーフな変更可能な文字シーケンス。 String に似た文字列バッファですが、変更できません。もちろん、最も重要な点はスレッドの安全性です。ソース コードから、同期を実現するためにスレッド制御ブロックが一部の操作 (追加、挿入など) に使用されていることがわかります。これは、マルチスレッドでの使用に適しています。コードは次のとおりです:
public synchronized StringBuffer append(Object obj) {
super.append(String.valueOf(obj));
return this;
}
public synchronized StringBuffer append(String str) {
super.append(str);
return this;
}
public synchronized StringBuffer delete(int start, int end) {
super.delete(start, end);
return this;
}
/**
* @throws StringIndexOutOfBoundsException {@inheritDoc}
* @since 1.2
*/
public synchronized StringBuffer deleteCharAt(int index) {
super.deleteCharAt(index);
return this;
}
Construction
new StringBuffer(StringBuilder str)
一般的に使用されるメソッド
String Buffer append(str) は、 type str この文字列の末尾に追加します (String, char, char[], int, double, float, long, StringBuffer, StringBuilder)
StringBuffer insert(int offest, str) 指定された型の str をこのシーケンスに挿入します。 offset 挿入の開始位置を示すインデックス。型には String、char、char[]、int、double、float、long、StringBuffer、StringBuilder が含まれます。
String delete(int fromIndex,int endIndex) はこのシーケンス内の文字列を削除し、新しいバッファ文字列を返します
StringBuffer reverse() は文字列を反転します
String substring(int start) は現在の文字サブシーケンスを含む新しい文字列を返しますこの文字シーケンスに含まれる。
String substring(int start, int end) このシーケンスに現在含まれている文字のサブシーケンスを含む新しい String を返します。
StringBuffer deleteCharAt(int index) このシーケンス内の指定された位置にある文字を削除します。
int length() length
String toString() このシーケンス内のデータの文字列表現を返します。
StringBuilder
ほとんどの実装では StringBuffer よりも高速なため、このクラスを優先して使用することをお勧めします。ただし、このクラスはスレッドセーフではなく、シングルスレッドにのみ適しています。マルチスレッドを使用する場合は、もちろん StringBuffer を使用することをお勧めしますが、同期を自分で実装する必要があります。構築メソッド
new StringBuilder(String str)
共通メソッド
このクラスの共通メソッドはここでは一つずつ列挙しません。上記を参考にしてください
以上がJava 文字列の高度なサンプル コード共有 (コレクション)の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。