MN
Size: a a a
MN
MN
MN
MN
I
Р
AE
public static void main(String[] args){Он достаточно прост, N-раз вызывается некоторая ф-ция, которая обрабатывает это число n.
for (int i = 0; i < 100000000; i++) {
isNonNegative(5);
}
}
private static void isNonNegative(int num) {
if (num >= 0) {
// Some operations here...
int a = num / 1000 - 50;
if (a < 0) a = -1 * a;
int result = fastFibonacci(a);
} else {
// Some operations here...
int result = slowFibonacci(num);
}
}
isNonNegativeВторое, мне показалось, что вторую ветку с else-условием в принципе можно опустить на уровне assembler-кода. Я решил посмотреть чем в действительности отличается компиляция client/server компиляторов (https://ibb.co/3yQCfH1 и https://ibb.co/f8zN94Y). На сколько я понял из этих скринов, всё таки C2 решил затереть else-бранчу.
isNonNegative, убирая else-ветку?
MN
public static void main(String[] args){Он достаточно прост, N-раз вызывается некоторая ф-ция, которая обрабатывает это число n.
for (int i = 0; i < 100000000; i++) {
isNonNegative(5);
}
}
private static void isNonNegative(int num) {
if (num >= 0) {
// Some operations here...
int a = num / 1000 - 50;
if (a < 0) a = -1 * a;
int result = fastFibonacci(a);
} else {
// Some operations here...
int result = slowFibonacci(num);
}
}
isNonNegativeВторое, мне показалось, что вторую ветку с else-условием в принципе можно опустить на уровне assembler-кода. Я решил посмотреть чем в действительности отличается компиляция client/server компиляторов (https://ibb.co/3yQCfH1 и https://ibb.co/f8zN94Y). На сколько я понял из этих скринов, всё таки C2 решил затереть else-бранчу.
isNonNegative, убирая else-ветку?
ЖМ
public static void main(String[] args){Он достаточно прост, N-раз вызывается некоторая ф-ция, которая обрабатывает это число n.
for (int i = 0; i < 100000000; i++) {
isNonNegative(5);
}
}
private static void isNonNegative(int num) {
if (num >= 0) {
// Some operations here...
int a = num / 1000 - 50;
if (a < 0) a = -1 * a;
int result = fastFibonacci(a);
} else {
// Some operations here...
int result = slowFibonacci(num);
}
}
isNonNegativeВторое, мне показалось, что вторую ветку с else-условием в принципе можно опустить на уровне assembler-кода. Я решил посмотреть чем в действительности отличается компиляция client/server компиляторов (https://ibb.co/3yQCfH1 и https://ibb.co/f8zN94Y). На сколько я понял из этих скринов, всё таки C2 решил затереть else-бранчу.
isNonNegative, убирая else-ветку?
AE
ЖМ
o
AE
DB
DB
DB
AE
DB
AE