public abstract class CollationKey extends Object implements Comparable<CollationKey>
CollationKey
は、特定の Collator
オブジェクトのルールのもとにある String
を表します。2 つの CollationKey
オブジェクトを比較すると、それらが表す String
の相対的な順序が返されます。CollationKey
を使用して String
を比較する方が一般に Collator.compare
よりも高速です。したがって、複数の String
を何回も比較する場合 (たとえば、String
のリストをソートする場合) には、CollationKey
を使う方が効率的です。
CollationKey
を直接作成することはできません。それらを生成するには、Collator.getCollationKey
を呼び出す必要があります。CollationKey
を比較する場合、それらは同じ Collator
オブジェクトから生成しなければいけません。
String
の CollationKey
を生成するためには、String
全体を調べ、それを、ビット単位で比較できるビット列に変換する必要があります。こうすると、キーが生成されたあとで、比較が高速に行われます。キーを生成するコストは、String
を何回も比較する必要がある場合には、高速な比較によって埋め合わせることができます。一方、比較の結果は、それぞれの String
の最初の 2 文字で決まることがよくあります。
Collator.compare
では、必要な文字数だけが比較されるので、単一の比較ではこの方が高速です。
次の例は、CollationKey
を使って、String
のリストをソートする場合を示したものです。
// Create an array of CollationKeys for the Strings to be sorted. Collator myCollator = Collator.getInstance(); CollationKey[] keys = new CollationKey[3]; keys[0] = myCollator.getCollationKey("Tom"); keys[1] = myCollator.getCollationKey("Dick"); keys[2] = myCollator.getCollationKey("Harry"); sort( keys );
//...
// Inside body of sort routine, compare keys this way if( keys[i].compareTo( keys[j] ) > 0 ) // swap keys[i] and keys[j]
//...
// Finally, when we've returned from sort. System.out.println( keys[0].getSourceString() ); System.out.println( keys[1].getSourceString() ); System.out.println( keys[2].getSourceString() );
修飾子 | コンストラクタと説明 |
---|---|
protected |
CollationKey(String source)
CollationKey のコンストラクタです。
|
修飾子と型 | メソッドと説明 |
---|---|
abstract int |
compareTo(CollationKey target)
この CollationKey をターゲットの CollationKey と比較します。
|
String |
getSourceString()
この CollationKey が表す String を返します。
|
abstract byte[] |
toByteArray()
CollationKey をビット列に変換します。
|
protected CollationKey(String source)
source
- ソース文字列。NullPointerException
- source
が null である場合。public abstract int compareTo(CollationKey target)
compareTo
、インタフェース: Comparable<CollationKey>
target
- ターゲットの CollationKeyCollator.compare(java.lang.String, java.lang.String)
public String getSourceString()
public abstract byte[] toByteArray()
バグまたは機能を送信
詳細な API リファレンスおよび開発者ドキュメントについては、Java SE のドキュメントを参照してください。そのドキュメントには、概念的な概要、用語の定義、回避方法、有効なコード例などの、開発者を対象にしたより詳細な説明が含まれています。
Copyright © 1993, 2013, Oracle and/or its affiliates. All rights reserved.