关于printf格式输出字符串的坑


后记(上面的图有错误的地方,无论是堆还是栈,都是一个数的低位先进后出,因为这是小端模式)

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;
	
}

结果如下:
关于printf格式输出字符串的坑_第1张图片

总结:堆中定义的字符串强转整数,会带来很多意想不到坑!强转过程中,*P内中数据存储顺序都会以 4字节 为单位而改变!
再次输出时,其顺序就会前4字节和四字节整体交换。

你可能感兴趣的:(思维导图集)