JavaでのString、StringBuffer、StringBuilderの違い–例を添付
公開: 2022-01-30
このJavaチュートリアルでは、Java String、StringBuffer、StringBuilderの違いについて説明します。
始めましょう:
ストリング:
Stringクラスは、文字列を表します。 「crunchify」などのJavaプログラムのすべての文字列リテラルは、このクラスのインスタンスとして実装されます。 文字列は定数です。 作成後に値を変更することはできません。
StringBuffer:
スレッドセーフで変更可能な文字シーケンス。 文字列バッファは文字列に似ていますが、変更できます。
どの時点でも、特定の文字シーケンスが含まれていますが、シーケンスの長さと内容は、特定のメソッド呼び出しによって変更できます。
文字列バッファは、複数のスレッドで安全に使用できます。
StringBuilder:
文字の可変シーケンス。 このクラスは、StringBufferと互換性のあるAPIを提供しますが、同期の保証はありません。
このクラスは、文字列バッファが単一のスレッドによって使用されていた場所でのStringBufferのドロップイン置換として使用するように設計されています(一般的にそうであるように)。
可能であれば、ほとんどの実装で高速になるため、このクラスをStringBufferよりも優先して使用することをお勧めします。
String、StringBuffer、StringBuilderの以下のすべての特性を比較してみましょう。
ストリング | StringBuffer | StringBuilder | |
---|---|---|---|
スレッドセーフ? | はい | はい | 番号 |
同期しましたか? | はい | はい | 番号 |
変更可能ですか? | いいえ(不変) | はい(変更可能) | はい(変更可能) |
保管所 | 文字列プール | ヒープ | ヒープ |
パフォーマンス | スロー | 速い | もっと早く |
Javaコード:
- クラスを作成します:CrunchifyStringVsStringBufferVsStringBuilder.java
- 以下のコードを入れてください
- ファイルを保存
このチュートリアルでは、文字列の合計を199999回追加、追加しています。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 |
package crunchify . com . tutorial ; /** * @author Crunchify.com * Program: Difference between String, StringBuffer and StringBuilder in Java - Example attached */ public class CrunchifyStringVsStringBufferVsStringBuilder { public static void main ( String [ ] args ) { // String: The String class represents character strings. All string literals // in Java programs, such as "abc", are implemented as instances of this class. // Strings are constant; their values cannot be changed after they are created. String buffers support mutable strings. // Because String objects are immutable they can be shared. String crunchifyString = "" ; long crunchifyBefore = System . currentTimeMillis ( ) ; for ( int i = 0 ; i < 199999 ; i ++ ) { crunchifyString = crunchifyString + "crunchify.com" ; } long crunchifyAfter = ( System . currentTimeMillis ( ) ) ; crunchifyPrint ( "Task Completion Time for String: " + ( crunchifyAfter - crunchifyBefore ) ) ; // StringBuffer: A thread-safe, mutable sequence of characters. A string buffer is like a String, // but can be modified. At any point in time it contains some particular sequence of characters, but the length // and content of the sequence can be changed through certain method calls. // // String buffers are safe for use by multiple threads. The methods are synchronized where necessary so that all // the operations on any particular instance behave as if they occur in some serial order that is consistent with the order // of the method calls made by each of the individual threads involved. // // The principal operations on a StringBuffer are the append and insert methods, // which are overloaded so as to accept data of any type. Each effectively converts a given datum to a string and then appends // or inserts the characters of that string to the string buffer. // The append method always adds these characters at the end of the buffer; // the insert method adds the characters at a specified point. crunchifyBefore = System . currentTimeMillis ( ) ; StringBuffer crunchifyStringBuffer = new StringBuffer ( ) ; for ( int i = 0 ; i < 199999 ; i ++ ) { crunchifyStringBuffer . append ( "crunchify.com" ) ; } crunchifyAfter = ( System . currentTimeMillis ( ) ) ; crunchifyPrint ( "Task Completion Time for StringBuffer: " + ( crunchifyAfter - crunchifyBefore ) ) ; // StringBuilder: A mutable sequence of characters. // This class provides an API compatible with StringBuffer, but with no guarantee of synchronization. // This class is designed for use as a drop-in replacement for StringBuffer in places where the string buffer was being used by a single thread // (as is generally the case). Where possible, // it is recommended that this class be used in preference to StringBuffer as it will be faster under most implementations. // // The principal operations on a StringBuilder are the append and insert methods, // which are overloaded so as to accept data of any type. Each effectively converts a given datum to a string and then appends // or inserts the characters of that string to the string builder. // The append method always adds these characters at the end of the builder; the insert method adds the characters at a specified point. crunchifyBefore = System . currentTimeMillis ( ) ; StringBuilder crunchifyStringBuilder ; crunchifyStringBuilder = new StringBuilder ( ) ; for ( int i = 0 ; i < 199999 ; i ++ ) { crunchifyStringBuilder . append ( "crunchify.com" ) ; } // OR using repeat(). // crunchifyStringBuilder.append("crunchify.com".repeat(199999)); // repeat(): Returns a string whose value is the concatenation of this string repeated count times. crunchifyAfter = ( System . currentTimeMillis ( ) ) ; crunchifyPrint ( "Task Completion Time for StringBuilder: " + ( crunchifyAfter - crunchifyBefore ) ) ; } private static void crunchifyPrint ( String s ) { System . out . println ( s ) ; } } |
IntelliJ IDEAコンソールの結果:
上記のプログラムをIntelliJIDEAまたはEclipseコンソールでJavaアプリケーションとして実行すると、次のようになります。

1 2 3 4 5 6 7 8 |
/ Users / app / app / Installation / jdk - 17.0.2.jdk / Contents / Home / bin / java - javaagent : / Applications / IntelliJ IDEA . app / Contents / lib / idea_rt . jar = 50109 : / Applications / IntelliJ IDEA . app / Contents / bin - Dfile . encoding = UTF - 8 - classpath : / Users / app / . m2 / repository / org / slf4j / log4j - over - slf4j / 1.7.32 / log4j - over - slf4j - 1.7.32.jar crunchify . com . tutorial . CrunchifyStringVsStringBuffer Task Completion Time for String : 19648 Task Completion Time for StringBuffer : 7 Task Completion Time for StringBuilder : 3 Process finished with exit code 0 |
上記のプログラムの実行で問題が発生した場合、またはString、StringBuffer、StringBuilderの間で質問がある場合は、お知らせください。