Я завжди припускав, що, роблячи (a % 256)
оптимізатор, природно, буде використовувати ефективну побітну операцію, як ніби я писав (a & 0xFF)
.
Під час тестування на компіляторі explorer gcc-6.2 (-O3):
// Type your code here, or load an example.
int mod(int num) {
return num % 256;
}
mod(int):
mov edx, edi
sar edx, 31
shr edx, 24
lea eax, [rdi+rdx]
movzx eax, al
sub eax, edx
ret
І при спробі іншого коду:
// Type your code here, or load an example.
int mod(int num) {
return num & 0xFF;
}
mod(int):
movzx eax, dil
ret
Здається, я щось зовсім пропускаю. Будь-які ідеї?
%
не є &
.
num
є unsigned
?