今天看见论坛中有人发表一段代码:
#include<stdio.h>
int main()
{
int a='abc';
printf("%s\n",&a);
return 0;
}
这段代码输出cba,a=6382179,abc对应的十六进制为ox00616263,整形存储单元对应的ASCII码为000 097 098 099。
若是机器为小端存储模式(数据的地位保存在内存的低地址位数据的高位存储在内存的高地址位)int a对应的值在内存中 的存储模式为0x63626100.
char型在内存中占一个字节,int型在内存中站4个字节,将char型拓展为int型,恰好00为null所以输出cba,若将‘abc’改为‘abcd’那么输出未必是dcba,因为不知道内存的下一个字节是否null,直到为null停止输出,但是若将‘abc’改为‘abcde’将会报错,因为类型不匹配。
测试大小端:
#include<stdio.h>
int main(void)
{
int a = 0x12345678;
unsigned char *p=(unsigned char *)&a;
if(0x78==*p)
{
printf("littleend\n");
}
else
{
printf("bigend\n");
}
return 0;
}