1.宏定义:
#include<iostream>
using namespace std;
#define add(a,b) a+b
int main(){
cout<<5*add(3,4)<<endl; //结果是5*3+4=17
}
2.枚举值
枚举类型限定了变量的取值
#include<iostream>
using namespace std;
#define add(a,b) a+b
int main(){
enum num1{
one,
two,
three
} Num1,Num2,Num3;
Num1=one;
Num2=two;
Num3=three;
enum num2{
a,
b=5,
c
} Num2_1,Num2_2,Num2_3;
Num2_1=a;
Num2_2=b;
Num2_3=c;
cout<<"num1-one="<<Num1<<" num1-two="<<Num2<<" num1-three="<<Num3<<endl;//0,1,2
cout<<"num2-a="<<Num2_1<<" num2-b="<<Num2_2<<" num2-c="<<Num2_3<<endl;//0,5,6
/*
1.枚举类型的默认值为从0开始,后一个值比前一个大一。
2.如果改变默认值,则该位置往下的值依然比前面大一,该位置前面的保持不变
*/
3.const常量
const定义的常量只能在定义时赋值,且之后不能修改。
#include<iostream>
using namespace std;
#define add(a,b) a+b
int main(){
const int a;
a=2;//出错,必须在定义时初始化
cout<<a;
}
4.参数传递顺序
#include<iostream>
using namespace std;
int f(int a,int b, int c)
{
return 0;
}
int main(){
return f(printf("a"),printf("b"),printf("c"));//依次输出cba
}
1.c++的参数传递顺序是从右到左的
2.printf()函数形式 ,可见参数格式是int类型,故不会报错
int printf ( const char * format, ... );
5.结构体存储对齐问题
- 结构体成员按照存储数据类型自身的对齐(即是:存储该变量的首地址%该变量类型所占字节=0)。
- 结构体按照结构体数据成员的最大储存值对齐。
看一下例子(假设是在32位系统下)32位下各数据类型及其所占字节。
char :1个字节
char*(即指针变量): 4个字节(32位的寻址空间是2^32, 即32个bit,也就是4个字节。同理64位编译器)
short int : 2个字节
int: 4个字节
unsigned int : 4个字节
float: 4个字节
double: 8个字节
long: 4个字节
long long: 8个字节
unsigned long: 4个字节
结构体如下
struct B
{
char b;//首地址0,0%1=0,首地址符合 故地址0-1自己存储b
int a;//地址2开始,2%4=2不满足对齐,跳到地址4(4%4=0),故4-7字节单元存储b
short c; //8%2=0,满足,故8-9存储c
/*故数据成员对齐后总共占用0-9即十字节,又根据结构体按照结构体数据成员的最大储存值对齐(10%4!=0)故增加到12字节(12%4=0);
*/
};