ホームページ > Java > &#&チュートリアル > Java 文字列の高度なチュートリアル

Java 文字列の高度なチュートリアル

巴扎黑
リリース: 2017-08-09 17:58:10
オリジナル
1430 人が閲覧しました

以下のエディターは、高度な 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;
}
ログイン後にコピー
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) は、このシーケンス内の文字列を削除します。 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 サイトの他の関連記事を参照してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート