后记(上面的图有错误的地方,无论是堆还是栈,都是一个数的低位先进后出,因为这是小端模式)
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 %ll