21世紀Cを読んで、第6章の「例外的な数値をNaNでマークする」セクションに到着しました。ここでは、仮数部のビットを使用して任意のビットパターンを格納し、マーカーまたはポインターとして使用する方法について説明しています(本の言及そのWebKitはこの手法を使用しています)。
このテクニックの有用性を理解したかどうかはよくわかりませんが、ハック(NaNの仮数の値を気にせずハードウェアに依存している)に見えますが、私は慣れていないJavaのバックグラウンドから来ていますCの粗さ
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));
}
それは印刷します:
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
そして、でJSValue.hの WebKitのエンコーディングを説明し、それが使われていない理由。
この手法の目的は何ですか?スペース/パフォーマンスの利点は、そのハック的な性質のバランスを取るのに十分ですか?