Skip to content

符号なし整数型

整数型に加えて、Kotlin は符号なし整数値のために以下の型を提供します。

サイズ (ビット)最小値最大値
UByte80255
UShort16065,535
UInt3204,294,967,295 (232 - 1)
ULong64018,446,744,073,709,551,615 (264 - 1)

符号なし型は、対応する符号あり型のほとんどの操作をサポートしています。

符号なし数は、インラインクラスとして実装されており、同じ幅の対応する符号あり型を含む単一のストレージプロパティを持っています。符号なし整数型と符号あり整数型の間で変換したい場合は、関数呼び出しと操作が新しい型をサポートするようにコードを更新してください。

符号なし配列と範囲

符号なし配列とその操作はベータ版です。これらはいつでも互換性のない変更が行われる可能性があります。オプトインが必要です (詳細は下記参照)。

プリミティブと同様に、各符号なし型には、その型の配列を表す対応する型があります。

  • UByteArray: 符号なしバイトの配列。
  • UShortArray: 符号なしショートの配列。
  • UIntArray: 符号なしイントの配列。
  • ULongArray: 符号なしロングの配列。

符号あり整数配列と同様に、ボクシングのオーバーヘッドなしでArrayクラスと似たAPIを提供します。

符号なし配列を使用すると、この機能がまだ安定していないことを示す警告が表示されます。警告を解消するには、@ExperimentalUnsignedTypesアノテーションでオプトインします。クライアントがAPIの使用に明示的にオプトインする必要があるかどうかは、あなたの判断に委ねられますが、符号なし配列は安定した機能ではないため、それらを使用するAPIは言語の変更によって壊れる可能性があることに留意してください。オプトイン要件について詳しくはこちら

範囲とプログレッションは、UIntおよびULongについて、UIntRangeUIntProgressionULongRangeULongProgressionクラスによってサポートされています。これらのクラスは、符号なし整数型とともに安定しています。

符号なし整数リテラル

符号なし整数を使いやすくするために、特定の符号なし型を示すサフィックスを整数リテラルに追加できます (例えば、FloatFLongLと同様に):

  • uUの文字は、厳密な型を指定せずに符号なしリテラルを示します。期待される型が提供されない場合、コンパイラはリテラルのサイズに応じてUIntまたはULongを使用します:

    kotlin
    val b: UByte = 1u  // UByte, expected type provided
    val s: UShort = 1u // UShort, expected type provided
    val l: ULong = 1u  // ULong, expected type provided
    
    val a1 = 42u // UInt: no expected type provided, constant fits in UInt
    val a2 = 0xFFFF_FFFF_FFFFu // ULong: no expected type provided, constant doesn't fit in UInt
  • uLULは、リテラルが符号なしロングであることを明示的に指定します:

    kotlin
    val a = 1UL // ULong, even though no expected type provided and the constant fits into UInt

ユースケース

符号なし数の主なユースケースは、整数の全ビット範囲を利用して正の値を表現することです。例えば、32ビットAARRGGBB形式の色のような、符号あり型に収まらない16進定数を表現する場合などです。

kotlin
data class Color(val representation: UInt)

val yellow = Color(0xFFCC00CCu)

明示的なtoByte()リテラルキャストなしでバイト配列を初期化するために、符号なし数を使用できます:

kotlin
val byteOrderMarkUtf8 = ubyteArrayOf(0xEFu, 0xBBu, 0xBFu)

もう1つのユースケースは、ネイティブAPIとの相互運用性です。Kotlinは、シグネチャに符号なし型を含むネイティブ宣言を表現することを可能にします。このマッピングは、意味論を変えることなく符号なし整数を符号あり整数に置換することはありません。

非目標

符号なし整数は正の数とゼロのみを表現できますが、アプリケーションドメインが非負整数を要求する場所でそれらを使用することは目標ではありません。例えば、コレクションのサイズやコレクションのインデックス値の型としてなどです。

理由はいくつかあります:

  • 符号あり整数を使用すると、偶発的なオーバーフローを検出し、エラー状態を通知するのに役立ちます。例えば、空のリストのList.lastIndexが-1になるなどです。
  • 符号なし整数は、その値の範囲が符号あり整数の範囲のサブセットではないため、符号あり整数の範囲制限されたバージョンとして扱うことはできません。符号あり整数も符号なし整数も、互いのサブタイプではありません。