[英]pointer offset doesnt work in memset?
普通的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字节整数),
int *p = 0x00004
int *q = p+1;
assert(q == 0x00008)
基本上,它与使用运算符索引的情况相同:
int *q = &p[1]
如果要将指针递增1,请将其unsigned char *
转换为unsigned char *
。 你这样做的方式是覆盖不属于变量a
内存,并可能覆盖现有数据。
b + 2 meens实际上是两个int而不是两个字节的位移。
unsigned int *b = &a;
memset(b+2, 0, 1);
实际上你想修改第三个字节
unsigned int *b = &a;
memset( ((char*)b)+2, 0, 1);
int仅保证至少为两个字节,因此如果要设置第三个字节,则应使用long int(或uint32_t)。 无论如何,我会使用bitwise和operator来完成它
unsigned long a = 4294967293;
/* regular code */
a &= 0xFFFF00FF;
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.