以下のエディターは、高度な Java 文字列に関する記事 (必読の記事) を提供します。編集者はこれがとても良いと思ったので、参考として共有します。エディターをフォローして、一緒に見てみましょう
前書き
文字列操作に最もよく使用される 3 つのクラス、つまり String、StringBuilder、および StringBuffer があります。これらの 3 つのクラスについては、以下で詳しく説明します。 ..
String
これは文字列の最も基本的なクラスです。ここでは詳しくは紹介しません。
new String(String str)new String(StringBuilder str)
new String(StringBuffer str)new String(byte[] bys,String charsetName) 指定された文字セットのバイト サブ配列を使用して、指定されたものをデコードします、新しい文字列を構築します。 共通メソッド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 で終わるかどうかを判断しますbooleanquals(Object o) 比較用int indexOf(char c) は文字 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();
StringBuffer
スレッドセーフな変更可能な文字シーケンス。 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; }
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) は、このシーケンス内の文字列を削除します。 returns 新しいバッファ文字列
StringBuffer reverse() 文字列を反転 String substring(int start) この文字シーケンスに現在含まれている文字部分シーケンスを含む新しい String を返します。 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 サイトの他の関連記事を参照してください。