认证0级讲师
まず、2つの(first == Second)ですが、firstがint(基本型)なので、==比較を行う際に、2番目はIntegerから分離されます。ボックスは int で、 == は値の比較を実行します。2 つの値 (最初は 127、2 回目は 128) が等しいため、どちらの時間も になります。 >true;(first == second),因为 first 是 int(基本类型),所以在进行 == 比较的时候,second 会从 Integer 拆箱为 int,然后 == 进行的是值比较 —— 因为两次值(第一次都为 127,第二次都为 128)都相等,所以两次都是 true;
(first == Second)
Integer
int
になります。 >true
(first == second)
true
在看两个 (second == third),second 和 third 都是 Integer(对象),所以 == 比较的时候,比较的是对象的引用,如果两个引用指向的是同一块内存(同一个对象),那么返回 true,否则返回 false。second = 127; 这样的代码其实是 Java 的语法糖,真正执行的是 second = Integer.valueOf(127),我们来看看 Integer.valueOf 的源码:
(second == third)
false
second = 127;
second = Integer.valueOf(127)
Integer.valueOf
很容易理解,Integer 的内部缓存了 IntegerCache.low ~ IntegerCache.high 的 Integer,所以如果传入的整数参数 i 在这个范围之内的话,那么返回的就是缓存的对象,否则才新建一个 Integer。在 Oracle 的 JVM 上,Integer 的缓存范围默认为 -128 ~ 127。所以每次调用 Integer.value(127) 返回的都是同一个被缓存的 Integer,而调用 Integer.value(128) 将每次新建一个 Integer(new Integer(128))。所以第一个(second == third)
Integer.value(127)
Integer.value(128)
Integer(new Integer(128))
(2 番目 == 3 番目)
を呼び出します。 >Integer(new Integer(128))
2 つの Ineger 型を == で比較します。値が -128 ~ 127 の場合は true を返し、そうでない場合は false を返します。これは Integer.valueof() のバッファー オブジェクトによるものです。
リーリー
オブジェクト間の比較は、特定の範囲内でのバッファリングにより結果に影響を与えます。
パッケージ化されたクラス(オブジェクト)と基本型の比較は、結果を得る直接的な比率です。
まず、2つの
(first == Second)
ですが、firstがint(基本型)なので、==比較を行う際に、2番目はInteger
から分離されます。ボックスはint
で、 == は値の比較を実行します。2 つの値 (最初は 127、2 回目は 128) が等しいため、どちらの時間もになります。 >true
;(first == second)
,因为 first 是 int(基本类型),所以在进行 == 比较的时候,second 会从Integer
拆箱为int
,然后 == 进行的是值比较 —— 因为两次值(第一次都为 127,第二次都为 128)都相等,所以两次都是true
;在看两个
(second == third)
,second 和 third 都是Integer
(对象),所以 == 比较的时候,比较的是对象的引用,如果两个引用指向的是同一块内存(同一个对象),那么返回true
,否则返回false
。second = 127;
这样的代码其实是 Java 的语法糖,真正执行的是second = Integer.valueOf(127)
,我们来看看Integer.valueOf
的源码:很容易理解,
2 つのInteger
的内部缓存了 IntegerCache.low ~ IntegerCache.high 的Integer
,所以如果传入的整数参数 i 在这个范围之内的话,那么返回的就是缓存的对象,否则才新建一个Integer
。在 Oracle 的 JVM 上,Integer
的缓存范围默认为 -128 ~ 127。所以每次调用Integer.value(127)
返回的都是同一个被缓存的Integer
,而调用Integer.value(128)
将每次新建一个Integer(new Integer(128))
。所以第一个(second == third)
(2 番目 == 3 番目)
を見ると、2 番目と 3 番目はどちらもInteger
(オブジェクト) なので、== を比較するときはオブジェクトの参照が比較されます。 2 つの参照が同じメモリ (同じオブジェクト) を指している場合はtrue
を返し、それ以外の場合はfalse
を返します。second = 127;
このようなコードは実際には Java の構文シュガーです。実際に実行されるのはsecond = Integer.valueOf(127)
です。 >Integer.valueOf のソース コード:🎜 🎜
Integer
が IntegerCache.low ~ IntegerCache.high のInteger
を内部的にキャッシュすることは容易に理解できるため、渡した整数パラメータがこの範囲内にある場合、キャッシュされたオブジェクトが返されます。それ以外の場合は、新しいInteger
が作成されます。 Oracle の JVM では、Integer
のキャッシュ範囲はデフォルトで -128 ~ 127 です。したがって、Integer.value(127)
を呼び出すたびに、キャッシュされた同じInteger
が返されますが、Integer.value(128)
は新しいを呼び出します。 >Integer(new Integer(128))
が毎回作成されます。したがって、最初の(2 番目 == 3 番目)
は true を返し、2 番目は false を返します。 🎜2 つの Ineger 型を == で比較します。値が -128 ~ 127 の場合は true を返し、そうでない場合は false を返します。これは Integer.valueof() のバッファー オブジェクトによるものです。
リーリー リーリーリーリー
オブジェクト間の比較は、特定の範囲内でのバッファリングにより結果に影響を与えます。
パッケージ化されたクラス(オブジェクト)と基本型の比較は、結果を得る直接的な比率です。