Czytając 21 wiek C Doszedłem do rozdziału 6 w sekcji „Oznaczanie wyjątkowych wartości liczbowych za pomocą NaNs” , gdzie wyjaśnia użycie bitów w mantysie do przechowywania niektórych dowolnych wzorów bitów, wykorzystywania ich jako znaczników lub wskaźników (książka wspomina że WebKit korzysta z tej techniki).
Nie jestem do końca pewien, czy zrozumiałem użyteczność tej techniki, którą widzę jako hack (polega ona na sprzęcie nie dbającym o wartość mantysy w NaN), ale pochodzącym ze środowiska Java, do którego nie jestem przyzwyczajony szorstkość C.
Oto fragment kodu, który ustawia i odczytuje znacznik w NaN
#include <stdio.h>
#include <math.h> //isnan
double ref;
double set_na(){
if (!ref) {
ref=0/0.;
char *cr = (char *)(&ref);
cr[2]='a';
}
return ref;
}
int is_na(double in){
if (!ref) return 0; //set_na was never called==>no NAs yet.
char *cc = (char *)(&in);
char *cr = (char *)(&ref);
for (int i=0; i< sizeof(double); i++)
if (cc[i] != cr[i]) return 0;
return 1;
}
int main(){
double x = set_na();
double y = x;
printf("Is x=set_na() NA? %i\n", is_na(x));
printf("Is x=set_na() NAN? %i\n", isnan(x));
printf("Is y=x NA? %i\n", is_na(y));
printf("Is 0/0 NA? %i\n", is_na(0/0.));
printf("Is 8 NA? %i\n", is_na(8));
}
drukuje:
Is x=set_na() NA? 1
Is x=set_na() NAN? 1
Is y=x NA? 1
Is 0/0 NA? 0
Is 8 NA? 0
a na stronie JSValue.h webkit wyjaśnia kodowanie, ale nie wyjaśnia, dlaczego jest używane.
Jaki jest cel tej techniki? Czy zalety przestrzeni / wydajności są wystarczająco wysokie, aby zrównoważyć jej hackerski charakter?