15

バイナリ ファイルがあるとします。正の 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;
}
4

3 に答える 3

20

これは、ビッグエンディアンまたはリトルエンディアンのアーキテクチャで機能する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;
}
于 2012-10-21T19:36:09.240 に答える
12

Linux を使用している場合は、こちらを参照してください;-)

le32tohなどの便利な機能についてです

于 2012-10-21T19:46:57.887 に答える
5

CodeGuruから:

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
}
于 2012-10-21T19:33:47.697 に答える