3

普通 C,在 Windows 7 和 HP 机器上。

int main(void) {

    unsigned int a =  4294967295;
    unsigned int *b = &a;

    printf("before val: '%u'\n", *b); // expect 4294967295, got 4294967295

    memset(b+2, 0, 1);

    printf("after val: '%u'\n", *b);
    // little endian          4th      3rd     2nd       1st
    // expect 4278255615 - 11111111 00000000 11111111 11111111
    // got    4294967295 - 11111111 11111111 11111111 11111111

    return 0;

}

我想将整数的第三个字节设置为 0x0,但保持不变。有任何想法吗?谢谢你。

在我的机器上,int 是 32 位。

4

3 回答 3

7

指针加法/减法不会只移动一个字节 - 它会移动被指向对象类型的大小。

也就是说(假设4字节整数),

int *p = 0x00004
int *q = p+1;
assert(q == 0x00008)

基本上,这与您使用运算符的索引相同:

int *q = &p[1]

如果要将指针加一,请将其强制转换为unsigned char *. 您这样做的方式是覆盖不属于变量的内存,a并可能为其他内容覆盖现有数据。

于 2012-05-11T15:25:32.090 回答
2

b+2 实际上是两个 int 而不是两个字节的位移。

 unsigned int *b = &a;
 memset(b+2, 0, 1);

其实你要修改第三个字节

 unsigned int *b = &a;
 memset( ((char*)b)+2, 0, 1);
于 2012-05-11T15:27:03.373 回答
0

int 只保证至少有两个字节,所以如果你想设置第三个字节,你应该使用 long int(或 uint32_t)。无论如何,我会使用按位和运算符来做到这一点

unsigned long a = 4294967293;
/* regular code */
a &= 0xFFFF00FF;
于 2012-05-11T15:27:37.183 回答