バイナリファイルがあるとしましょう。正の2進数が含まれていますが、 リトルエンディアン 32ビット整数として
このファイルを読み取るにはどうすればよいですか?私は今これを持っています。
int main() {
FILE * fp;
char buffer[4];
int num = 0;
fp=fopen("file.txt","rb");
while ( fread(&buffer, 1, 4,fp) != 0) {
// I think buffer should be 32 bit integer I read,
// how can I let num equal to 32 bit little endian integer?
}
// Say I just want to get the sum of all these binary little endian integers,
// is there an another way to make read and get sum faster since it's all
// binary, shouldnt it be faster if i just add in binary? not sure..
return 0;
}
これは、ビッグエンディアンまたはリトルエンディアンのアーキテクチャで機能する1つの方法です。
int main() {
unsigned char bytes[4];
int sum = 0;
FILE *fp=fopen("file.txt","rb");
while ( fread(bytes, 4, 1,fp) != 0) {
sum += bytes[0] | (bytes[1]<<8) | (bytes[2]<<16) | (bytes[3]<<24);
}
return 0;
}
Linuxを使用している場合は、 ここ ;-)を参照してください。
le32tohなどの便利な関数についてです
から CodeGur :
inline void endian_swap(unsigned int& x)
{
x = (x>>24) |
((x<<8) & 0x00FF0000) |
((x>>8) & 0x0000FF00) |
(x<<24);
}
したがって、unsigned int
を直接読んでから、これを呼び出すことができます。
while ( fread(&num, 1, 4,fp) != 0) {
endian_swap(num);
// conversion done; then use num
}