Java 文字列の高度なチュートリアル
以下のエディターは、高度な 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 サイトの他の関連記事を参照してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









Java の Weka へのガイド。ここでは、weka java の概要、使い方、プラットフォームの種類、利点について例を交えて説明します。

この記事では、Java Spring の面接で最もよく聞かれる質問とその詳細な回答をまとめました。面接を突破できるように。

Java 8は、Stream APIを導入し、データ収集を処理する強力で表現力のある方法を提供します。ただし、ストリームを使用する際の一般的な質問は次のとおりです。 従来のループにより、早期の中断やリターンが可能になりますが、StreamのForeachメソッドはこの方法を直接サポートしていません。この記事では、理由を説明し、ストリーム処理システムに早期終了を実装するための代替方法を調査します。 さらに読み取り:JavaストリームAPIの改善 ストリームを理解してください Foreachメソッドは、ストリーム内の各要素で1つの操作を実行する端末操作です。その設計意図はです

Java での日付までのタイムスタンプに関するガイド。ここでは、Java でタイムスタンプを日付に変換する方法とその概要について、例とともに説明します。

カプセルは3次元の幾何学的図形で、両端にシリンダーと半球で構成されています。カプセルの体積は、シリンダーの体積と両端に半球の体積を追加することで計算できます。このチュートリアルでは、さまざまな方法を使用して、Javaの特定のカプセルの体積を計算する方法について説明します。 カプセルボリュームフォーミュラ カプセルボリュームの式は次のとおりです。 カプセル体積=円筒形の体積2つの半球体積 で、 R:半球の半径。 H:シリンダーの高さ(半球を除く)。 例1 入力 RADIUS = 5ユニット 高さ= 10単位 出力 ボリューム= 1570.8立方ユニット 説明する 式を使用してボリュームを計算します。 ボリューム=π×R2×H(4

Java は、初心者と経験豊富な開発者の両方が学習できる人気のあるプログラミング言語です。このチュートリアルは基本的な概念から始まり、高度なトピックに進みます。 Java Development Kit をインストールしたら、簡単な「Hello, World!」プログラムを作成してプログラミングを練習できます。コードを理解したら、コマンド プロンプトを使用してプログラムをコンパイルして実行すると、コンソールに「Hello, World!」と出力されます。 Java の学習はプログラミングの旅の始まりであり、習熟が深まるにつれて、より複雑なアプリケーションを作成できるようになります。
