大小端模式,栈的生长方向和内存的存放方向
- /*
- 栈的生长方向和内存的存放方向
- 栈的开口向下,高地址在上,低地址在下
- 内存的存放方向:自下向上
- 大端模式下:栈的高地址对应数据的低位
- 小端模式下:栈的高地址对应于数据的高位
- */
- #define _CRT_SECURE_NO_WARNINGS
- #include <stdio.h>
- #include <stdlib.h>
- #include <string.h>
- //1. 栈的生长方向
- void test01(){
- int a = 10;
- int b = 20;
- int c = 30;
- int d = 40;
- printf("a = %d\n", &a);
- printf("b = %d\n", &b);
- printf("c = %d\n", &c);
- printf("d = %d\n", &d);
- //a的地址大于b的地址,故而生长方向向下
- }
- //2. 内存生长方向(小端模式)
- void test02(){
- //高位字节 -> 地位字节
- int num = 0xaabbccdd;
- unsigned char* p = (unsigned char *)#
- //从首地址开始的第一个字节
- printf("%x\n", *p);
- printf("%x\n", *(p + 1));
- printf("%x\n", *(p + 2));
- printf("%x\n", *(p + 3));//此处指针指到数据部分最上端,即输出为aa,栈的高地址对应于数据的高位
- }
- void main()
- {
- test01();
- test02();
- system("pause");
- }
int main( void )
{
short int a;
char x;
a = 0x1122;
printf("*(char*)&a = 0x%x\n", *(char*)&a );
printf("(char)a = 0x%x\n", (char)a );
return 0;
}
本例是测大小端用的,两个printf输出为:小端两个printf都为0x22,
大端:
printf("*(char*)&a = 0x%x\n", *(char*)&a ); 0x11
printf("(char)a = 0x%x\n", (char)a ); 0x22 short强转位char,保留的是数据的最低8位,非最低内存地址的值
UINT64 test64 = 0X12345678;
UINT32 test32 = test64; /* 不管是大端还是小端,test32的值都是0x12345678 */