一道C语言试题求讲解,十分感谢!!
下面这段程序运行的结果是:Ainta=0x4145;char*p;p=(char*)&a;*p+=1;printf(“%X”,*p);A.46B.42C.4146D.42...
下面这段程序运行的结果是:A
int a=0x4145;
char *p;
p=(char *)&a;
*p+=1;
printf(“%X” , *p);
A. 46 B. 42 C.4146 D.4245
p=(char *)&a; 这句话什么意思呢~ p指向的是什么? *p等于45为什么~ 一头雾水,望详细讲解,谢谢~~~ 展开
int a=0x4145;
char *p;
p=(char *)&a;
*p+=1;
printf(“%X” , *p);
A. 46 B. 42 C.4146 D.4245
p=(char *)&a; 这句话什么意思呢~ p指向的是什么? *p等于45为什么~ 一头雾水,望详细讲解,谢谢~~~ 展开
6个回答
展开全部
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 在内存占 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<stdio.h>
int main(void)
{
int a=0x4145;
char *p;
p=(char *)&a; //指向char的指针,p指向0x45
*p+=1; //0x45+1
printf("%X", *p); //输出0x46
return 0;
}
//欢迎在线讨论
#include<stdio.h>
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的地址.因为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
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询