1.宏定义
宏定义只是用宏名对一个字符串进行简单的替换
优点:(1) 方便程序的修改
:(2) 提高程序的运行效率
2.内存分配方式
C++程序在执行时,将内存大方向划分为4个区域
代码区:存放函数体的二进制代码,由操作系统进行管理的
全局区:存放全局变量和静态变量以及常量
栈区:由编译器自动分配释放, 存放函数的参数值,局部变量等
堆区:由程序员分配和释放,若程序员不释放,程序结束时由操作系统回收
3.写程序判断系统是大端序还是小端序
大端模式:数据的高位,存放在地址的低位。(高位存低位,低位存高位) “123” 3是低位数据 1是高位数据
小端模式:数据的高位,存放在地址的高位。(高位存高位,低位存低位)
我们的pc机一般都是小端模式,
判断大小端模式程序:
第一种:用位移方法
#include<stdio.h>
#include<iostream>
int main()
{
unsigned short n = 1;
(((n) >> 8) ? (printf("Big\n")) : (printf("Little!\n")));
system("pause");
return 0;
}
//、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、
#include <iostream>
using namespace std;
int main()
{
int a = 1;
if((a >> 8))
cout << "big endian" << endl;
else
cout << "little endian" << endl;
system("pause");
return 0;
}
如果真正理解了大小端模式的原理,本质。用位移来操作,个人感觉是比较简单和比较正确的。因为大小端模式就是位的问题,所以用位移法表明你真正理解了本质。变量右移8(因为a = 1,变成二进制为:0000 0001 所以其实右移一位就可以判断了。)左边不够补0。所以就可以判断了,如果1存放在高位,右移8位后1还是存在的;如果1存放在低位,右移8位后1将被移出数据,所以不存,结果为0。
地址: 高地址 <<====== 低地址
小端模式存放:0000 0001 >> 8 == 0000 0000