La siguiente implementación de square produce una serie de sentencias cmp / je como esperaría de una sentencia if encadenada:
int square(int num) {
if (num == 0){
return 0;
} else if (num == 1){
return 1;
} else if (num == 2){
return 4;
} else if (num == 3){
return 9;
} else if (num == 4){
return 16;
} else if (num == 5){
return 25;
} else if (num == 6){
return 36;
} else if (num == 7){
return 49;
} else {
return num * num;
}
}
Y lo siguiente produce una tabla de datos para el retorno:
int square_2(int num) {
switch (num){
case 0: return 0;
case 1: return 1;
case 2: return 4;
case 3: return 9;
case 4: return 16;
case 5: return 25;
case 6: return 36;
case 7: return 49;
default: return num * num;
}
}
¿Por qué gcc no puede optimizar el superior en el inferior?
Desmontaje para referencia: https://godbolt.org/z/UP_igi
EDITAR: curiosamente, MSVC genera una tabla de salto en lugar de una tabla de datos para el caso de cambio. Y sorprendentemente, el sonido metálico los optimiza para el mismo resultado.
return
s; los casos no tienen breaks
, por lo que el interruptor también tiene un orden específico de ejecución. La cadena if / else tiene retornos en cada rama, la semántica en este caso es equivalente. La optimización no es imposible . Como contraejemplo, icc no optimiza ninguna de las funciones.