后记(上面的图有错误的地方,无论是堆还是栈,都是一个数的低位先进后出,因为这是小端模式)
int main(void)
{
char *p= (char*)malloc(100);
//堆区由低地址往高地址分配。
//栈区相反从高地址王低地址分配。
strcpy(p,"123456789");
long long *pp=( long long *)p;
//int d=2;
//printf("%d %d\n",d++,++d);
printf("%c %llx %c\n",*pp,*pp,*pp);
/*printf 时候,系统默认按照 栈 空间存储的数据形式输出的,
局部从高地址开始打印往低地址打印,整体依然遵守堆出堆顺序从低地址往高地址执行。
每当强转为字符的时候,后面就《pack(4)》系统默认4字节对齐。
***同一个函数内对同一个地址的操作,
操作地址有连续性即按顺序执行。*************/
printf("%llx %c %llx %c\n",*pp,*pp,*pp,*pp);
printf("%c %c %c \n",*pp,*pp,*pp);
printf("%llx %llx %llx\n",*pp,*pp,*pp);//
printf("%c %lx %c %lx\n",*pp,*pp,*pp,*pp);
printf("%lx %c %lx %c\n",*pp,*pp,*pp,*pp);
/*
printf("%p\n",pp);
printf("%p\n",p);
int slen;
printf("hello world%n",&slen);//%n表示字符串数量
printf(" %d",slen);//用std=c99,则输出字符串个数11。
*/
return 0;
}
结果如下:
总结:堆中定义的字符串强转整数,会带来很多意想不到坑!强转过程中,*P内中数据存储顺序都会以 4字节 为单位而改变!
再次输出时,其顺序就会前4字节和四字节整体交换。