Windowsの使用
だから私はバイナリファイルからunsignedintデータ値のリストを読んでいます。このファイルには、順番にリストされた多数のデータセットが含まれています。開始を指すchar*から単一のデータセットを読み取る関数は次のとおりです。
function read_dataset(char* stream, t_dataset *dataset){
//...some init, including setting dataset->size;
for(i=0;i<dataset->size;i++){
dataset->samples[i] = *((unsigned int *) stream);
stream += sizeof(unsigned int);
}
//...
}
このようなコンテキストでのread_datasetの場合:
//...
char buff[10000];
t_dataset* dataset = malloc( sizeof( *dataset) );
unsigned long offset = 0;
for(i=0;i<number_of_datasets; i++){
fseek(fd_in, offset, SEEK_SET);
if( (n = fread(buff, sizeof(char), sizeof(*dataset), fd_in)) != sizeof(*dataset) ){
break;
}
read_dataset(buff, *dataset);
// Do something with dataset here. It's screwed up before this, I checked.
offset += profileSize;
}
//...
私のループが番号2573を読み取るまで、すべてが順調に進みます。突然、ランダムで巨大な番号が吐き出され始めます。
たとえば、どうあるべきか
...
1831
2229
2406
2637
2609
2573
2523
2247
...
になります
...
1831
2229
2406
2637
2609
0xDB00000A
0xC7000009
0xB2000008
...
それらの16進数が疑わしいと思われる場合は、その通りです。変更された値の16進値は非常によく知られていることがわかります。
2573 -> 0xA0D
2523 -> 0x9DB
2247 -> 0x8C7
したがって、明らかにこの番号2573により、ストリームポインタが1バイトを取得します。これは、次のデータセットがロードされて解析されるまで続き、神はそれが番号2573を含むことを禁じています。これが発生するスポットをいくつかチェックしました。チェックした各スポットは2573から始まりました。
私はCの世界ではそれほど才能がないことを認めます。これを引き起こす可能性のあるものは、私には完全に不透明です。