如何访问整数形式的字节

时间:2018-12-27 11:14:39

标签: c

我试图在.bmp文件中像素的字节(或八位字节)与随机生成的整数中的3个字节(不包括最大字节)之间做 xor 重要的。我有点理解,最高有效字节取决于字节序,通常它是句子中传输的第一个字节。 在pix数组中,我存储了每个像素的每个八位位组。 wh都等于800,并且是.bmp图片的尺寸(800 x 800),并且R是随机数的数组。

我尝试执行以下操作,但是在进行一些递增操作后会出现分段错误

unsigned char *pix = malloc((3 * w * h) * sizeof(unsigned char));

for(int i = 0; i < (3 * w * h); i++)
    fread(&pix[i], sizeof(char), 1, fin);

uint32_t *R = malloc((3 * ((2 * w * h) - 1)) * sizeof(uint32_t));
unsigned char bytes[4];

for(k = 0; k < (3 * w * h); k = k + 3)
{
    bytes[0] = (R[3 * w * h + k] >> 24) & 0xFF;
    bytes[1] = (R[3 * w * h + k] >> 16) & 0xFF;
    bytes[2] = (R[3 * w * h + k] >> 8)  & 0xFF;
    bytes[3] =  R[3 * w * h + k]        & 0xFF;

    ch[k]     = bytes[1] ^ pix[k];
    ch[k + 1] = bytes[2] ^ pix[k + 1];
    ch[k + 2] = bytes[3] ^ pix[k + 2]
}

1 个答案:

答案 0 :(得分:-1)

typedef enum
{
    LITTLE = 0xff000000,
    BIG = 0x000000ff,
}ENDIANESS;

static ENDIANESS endianess;

ENDIANESS DetectEndianess(void)
{
    union
    {
        uint8_t u8[sizeof(unsigned int)];
        unsigned int u;
    }udata = {.u = 0xff};

    return (endianess = (udata.u8[0] == 0xff ? LITTLE : BIG));
}

static inline ENDIANESS GetEndianess(void)
{
    return endianess;
}

uint32_t GetUint32FromRGB(uint8_t *ptr)
{
    union u32u
    {
        uint8_t u8[4];
        uint32_t u32;
    }union32 = (GetEndianess() == LITTLE ? (union u32u){.u8[0] = *ptr, .u8[1] = *(ptr + 1), .u8[2] = *(ptr + 2)} : (union u32u){.u8[2] = *ptr, .u8[1] = *(ptr + 1), .u8[0] = *(ptr + 2)});

    return union32.u32 & GetEndianess();
}

uint32_t Xor3LowerBytes(uint32_t a, uint32_t b)
{
    return (a & GetEndianess()) ^ (b & GetEndianess());
}

或者,如果您不在乎邻接症(在此示例中为LITTLE)

uint32_t Xor3lowerBytes(void *ptr, uint32_t value)
{
    uint32_t *u32 = ptr;

    return (*u32 & 0xff000000) ^ value;
}