大小端模式,栈的生长方向和内存的存放方向

论坛 期权论坛 脚本     
匿名网站用户   2020-12-20 00:17   40   0

/*
栈的生长方向和内存的存放方向
栈的开口向下,高地址在上,低地址在下
内存的存放方向:自下向上
大端模式下:栈的高地址对应数据的低位
小端模式下:栈的高地址对应于数据的高位
*/
#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");
}


分享到 :
0 人收藏
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

积分:1136255
帖子:227251
精华:0
期权论坛 期权论坛
发布
内容

下载期权论坛手机APP