Sto avendo un bizzarro problema con C++ in cui il lungo tipo di dati sta straripando molto prima di quanto dovrebbe. Quello che sto facendo (con successo finora) è che gli interi si comportano come float, quindi l'intervallo [-32767,32767] è mappato a [-1.0,1.0]. Dove si imbatte è con argomentazioni più grandi che rappresentano galleggia maggiore di 1,0:C++ traboccante a lungo prima del tempo
inline long times(long a, long b) {
printf("a=%ld b=%ld ",a,b);
a *= b;
printf("a*b=%ld ",a);
a /= 32767l;
printf("a*b/32767=%ld\n",a);
return a;
}
int main(void) {
printf("%ld\n",times(98301l,32767l));
}
quello che ottengo come output è:
a=98301 b=32767 a*b=-1073938429 a*b/32767=-32775
-32775
così volte (98301,32767) è analogo al 3.0 * 1.0. Questo codice funziona perfettamente quando gli argomenti per i tempi sono inferiori a 32767 (1.0), ma nessuno dei passaggi intermedi con gli argomenti precedenti deve superare i 64 bit di lunghezza.
Qualche idea?
Puoi accettare la risposta quindi, rende le persone più disponibili ad aiutarti in futuro. –