/* * Copyright (c) 2010, 2018, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it * under the terms of the GNU General Public License version 2 only, as * published by the Free Software Foundation. * * This code is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License * version 2 for more details (a copy is included in the LICENSE file that * accompanied this code). * * You should have received a copy of the GNU General Public License version * 2 along with this work; if not, write to the Free Software Foundation, * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. * * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA * or visit www.oracle.com if you need additional information or have any * questions.
*/
/** * @test * @bug 6909839 * @summary missing unsigned compare cases for some cmoves in sparc.ad * * @run main/othervm -XX:+IgnoreUnrecognizedVMOptions -XX:+EliminateAutoBox -XX:AutoBoxCacheMax=20000 -Xbatch compiler.codegen.Test6909839
*/
staticvoid testui() { int total = 0; for (int i = 0 ; i < 10000; i++) { int v = i % 4;
total += ((v >= 1 && v < 3) ? 1 : 2);
}
System.out.println(total);
}
staticvoid testdi() { int total = 0; for (int i = 0 ; i < 10000; i++) { int v = i % 4;
total += (v > 1.0) ? 1 : 2;
}
System.out.println(total);
}
staticvoid testfi() { int total = 0; for (int i = 0 ; i < 10000; i++) { int v = i % 4;
total += (v > 1.0f) ? 1 : 2;
}
System.out.println(total);
}
staticvoid testi() { int total = 0; for (int i = 0 ; i < 10000; i++) {
total += (i % 4 != 0) ? 1 : 2;
}
System.out.println(total);
}
staticvoid testul() { long total = 0; for (int i = 0 ; i < 10000; i++) { int v = i % 4;
total += ((v >= 1 && v < 3) ? 1L : 2L);
}
System.out.println(total);
}
staticvoid testdl() { long total = 0; for (int i = 0 ; i < 10000; i++) { int v = i % 4;
total += (v > 1.0) ? 1L : 2L;
}
System.out.println(total);
}
staticvoid testfl() { long total = 0; for (int i = 0 ; i < 10000; i++) { int v = i % 4;
total += (v > 1.0f) ? 1L : 2L;
}
System.out.println(total);
}
staticvoid testl() { long total = 0; for (int i = 0 ; i < 10000; i++) {
total += (i % 4 != 0) ? 1L : 2L;
}
System.out.println(total);
}
staticvoid testuf() { float total = 0; for (int i = 0 ; i < 10000; i++) { int v = i % 4;
total += ((v >= 1 && v < 3) ? 1.0f : 2.0f);
}
System.out.println(total);
}
staticvoid testdf() { float total = 0; for (int i = 0 ; i < 10000; i++) { int v = i % 4;
total += (v > 0.0) ? 1.0f : 2.0f;
}
System.out.println(total);
}
staticvoid testff() { float total = 0; for (int i = 0 ; i < 10000; i++) { int v = i % 4;
total += (v > 0.0f) ? 1.0f : 2.0f;
}
System.out.println(total);
}
staticvoid testf() { float total = 0; for (int i = 0 ; i < 10000; i++) {
total += (i % 4 != 0) ? 1.0f : 2.0f;
}
System.out.println(total);
}
staticvoid testud() { double total = 0; for (int i = 0 ; i < 10000; i++) { int v = i % 4;
total += ((v >= 1 && v < 3) ? 1.0d : 2.0d);
}
System.out.println(total);
}
staticvoid testdd() { double total = 0; for (int i = 0 ; i < 10000; i++) { int v = i % 4;
total += (v > 1.0) ? 1.0d : 2.0d;
}
System.out.println(total);
}
staticvoid testfd() { double total = 0; for (int i = 0 ; i < 10000; i++) { int v = i % 4;
total += (v > 1.0f) ? 1.0d : 2.0d;
}
System.out.println(total);
}
staticvoid testd() { double total = 0; for (int i = 0 ; i < 10000; i++) {
total += (i % 4 != 0) ? 1.0d : 2.0d;
}
System.out.println(total);
}
staticvoid testp() {
Object a = new Object();
Object b = new Object(); int total = 0; for (int i = 0 ; i < 10000; i++) {
total += ((i % 4 != 0) ? a : b).hashCode();
}
System.out.println(total);
}
staticvoid testup() {
Object a = new Object();
Object b = new Object(); int total = 0; for (int i = 0 ; i < 10000; i++) { int v = i % 4;
total += ((v >= 1 && v < 3) ? a : b).hashCode();
}
System.out.println(total);
}
staticvoid testdp() {
Object a = new Object();
Object b = new Object(); int total = 0; for (int i = 0 ; i < 10000; i++) { int v = i % 4;
total += ((v > 1.0) ? a : b).hashCode();
}
System.out.println(total);
} staticvoid testfp() {
Object a = new Object();
Object b = new Object(); int total = 0; for (int i = 0 ; i < 10000; i++) { int v = i % 4;
total += ((v > 1.0f) ? a : b).hashCode();
}
System.out.println(total);
}
}
Die Informationen auf dieser Webseite wurden
nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit,
noch Qualität der bereit gestellten Informationen zugesichert.
Bemerkung:
Die farbliche Syntaxdarstellung und die Messung sind noch experimentell.