今日は、java.lang.Byte クラスのソース コードを分析して、本題に進みましょう
まず第一に
1 2 3 4 5 6 7 | public final class Byte extends Number implements Comparable<Byte> {
public static final byte MIN_VALUE = -128;
public static final byte MAX_VALUE = 127;
public static final int SIZE = 8;
public static final int BYTES = SIZE / Byte.SIZE;
@SuppressWarnings( "unchecked" )
public static final Class<Byte> TYPE = (Class<Byte>) Class.getPrimitiveClass( "byte" );
|
ログイン後にコピー
最初の文は、Byte クラスは最終的に変更されており、継承することができないということです。 Number クラスであり、一連の数値型に使用できます。変換では、比較に使用できる Comparable インターフェイスを実装します。
2 番目と 3 番目の文は、バイトのサイズを定義します。これは 8 ビット、つまり 1 バイトです。
5 番目の文は Bytes、つまり SIZE/Byte.SIZE = 1 を占めます
警告に対してサイレントであると注釈が付けられた文は、このクラスの元のクラスを取得します。
1 2 3 4 5 6 | public Byte(byte value) {
this.value = value;
}
public Byte(String s) throws NumberFormatException {
this.value = parseByte(s, 10);
}
|
ログイン後にコピー
Byte クラスの 2 つのコンストラクターには制限があります。渡される値はバイト型の値である必要があり、文字列 s は数値に変換できる文字列である必要があります。そうでない場合はエラーが報告されます
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 | public static String toString(byte b) {
return Integer.toString((int)b, 10);
}
public String toString() {
return Integer.toString((int)value);
}
private static class ByteCache {
private ByteCache(){}
static final Byte cache[] = new Byte[-(-128) + 127 + 1];
static {
for (int i = 0; i < cache.length; i++)
cache[i] = new Byte((byte)(i - 128));
}
}
|
ログイン後にコピー
次のステップは、バイト型を文字列に変換する toString メソッドであり、その中で Integer が使用されています クラス
のメソッド 次の ByteCache メソッドは、バイト キャッシュ値を定義し、-128 ~ 127 を書き込みますこの範囲内にある場合、JVM はキャッシュ値を直接使用しますが、この範囲を超えると、前の記事で述べたように、128 が -128 になり、計算がオーバーフローします。 parseByteは文字列型をバイト型に解析し、基数は10進数になります
1 2 3 4 5 6 7 8 9 10 11 | public static Byte valueOf(byte b) {
final int offset = 128;
return ByteCache.cache[(int)b + offset];
}
public static Byte valueOf(String s, int radix)
throws NumberFormatException {
return valueOf(parseByte(s, radix));
}
public static Byte valueOf(String s) throws NumberFormatException {
return valueOf(s, 10);
}
|
ログイン後にコピー
ここで、パラメータの基数をバイト型に変換する方法は、まず文字列を 10 進数に解析してから、valueOf
1 2 3 4 5 6 7 | public static Byte decode(String nm) throws NumberFormatException {
int i = Integer.decode(nm);
if (i < MIN_VALUE || i > MAX_VALUE)
throw new NumberFormatException(
"Value " + i + " out of range from input " + nm);
return valueOf((byte)i);
}
|
ログイン後にコピー
を実行することです。以前のメソッドはこのように書かれていませんでしたが、Integer クラスの decode メソッドを直接呼び出して、最小値より小さいか最大値より大きいかを判断し、バイト型に変換して返すようになりました。これは、「Java にはバイト型が存在しない」という文に実際に答えています
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 | public byte byteValue() {
return value;
}
public short shortValue() {
return (short)value;
}
public int intValue() {
return (int)value;
}
public long longValue() {
return (long)value;
}
public float floatValue() {
return (float)value;
}
public double doubleValue() {
return (double)value;
}
|
ログイン後にコピー
これらは、強制型変換のいくつかのメソッドであり、非常に単純ですが、それでも私はそれを書きました
1 2 3 4 5 6 7 | @Override
public int hashCode() {
return Byte.hashCode(value);
}
public static int hashCode(byte value) {
return (int)value;
}
|
ログイン後にコピー
最初の A hashCode は、Object の hasnCode メソッドを書き換え、 hashCode メソッドは、特にインタビューの際に、equals メソッドと区別されることがよくあります。hashCode メソッドは、主にコレクションで使用されます。
1 2 3 4 5 6 | public boolean equals(Object obj) {
if (obj instanceof Byte) {
return value == ((Byte)obj).byteValue();
}
return false;
}
|
ログイン後にコピー
メソッドが比較に使用できるようになりました。
1 2 3 4 5 6 | public int compareTo(Byte anotherByte) {
return compare(this.value, anotherByte.value);
}
public static int compare(byte x, byte y) {
return x - y;
}
|
ログイン後にコピー
比較メソッドは、x > y の場合は正の数を返し、x = y の場合は 0 を返します。 x < yの場合は負の数を返す
1 2 3 4 5 6 | public static int toUnsignedInt(byte x) {
return ((int) x) & 0xff;
}
public static long toUnsignedLong(byte x) {
return ((long) x) & 0xffL;
}
|
ログイン後にコピー
byte型をunsigned int型とlong型に変換する
1 | private static final long serialVersionUID = -7183698231559129828L;
|
ログイン後にコピー
今はあまり説明しないし、シリアル化も理解していない。のプロセス。 。 。 。
java intからbyte、longからbyte
Javaのバッファソースコードの解析
以上がJavaのByteクラスのソースコードを詳細に解析 - 手順の詳細の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。