p=(char *)&a;将a的地址转换为字符指针,也就是原来放的整数0x4145现在当成字符串来解释,在内存里面0x4145是这样存放的,先在一个低字节里放0x45再在接下来的一个高字节里放0x41,Intel的CPU是小端字节处理器,也就是说如果一个对象需要超过一个字节的内存来存放,那么它的地址就是最低的那个字节的地址,0x4146的地址就是存放0x45那个单元的地址,p指向0x4145于是p实际就是0x45那一个单元的地址,*p就取出了0x45这个值。。。。明白了吧。
int a=0x4145;
a 在内存占 4 个字节,Ox45存放在低字节,Ox41存放在高字节
char *p;
p 是一个指向单个字符的指针,这就决定了它的运算规则,指针运算符 * 也只取1个字节的值。
p=(char *)&a;
p 指向 a 的那块内存首地址,即指向Ox45
*p+=1;
p 指向的那个字节的值自增,即Ox45+1 = Ox46
printf(“%X” , *p);
以十六进制输出 p 指向的内存的值
A
//欢迎在线讨论
#include
int main(void)
{
int a=0x4145;
char *p;
p=(char *)&a; //指向char的指针,p指向0x45
*p+=1; //0x45+1
printf("%X", *p); //输出0x46
return 0;
}
int a=0x4145;在内存中, 低位字节在前,高位字节在后,即0x45,0x41.
&在这做取址符.即获得a的地址.因为a 是整形是,而p是指向字符型,即从所指地址读一个字节,通过(char *)强制把整形的地址转化为字符型,
即p指向0x45,加1后成0x46
我觉得答案应该是A吧,c的语法我忘的差不多了,不过*p是char型的,在内存中指向两个字节的数据,而a是int型的,是4个字节,第三句话应该是与a相与,1和0相与就是0,1和1相与不变,a是16进制,那么就保留最后的两位,即45,指针p再加1的话就是46,用排除法也可以做出来。
答案不是A就是B