#define和const常量的区别:
1、类型和安全检查不同:宏定义是字符替换,没有数据类型的区别,同时这种替换没有类型安全检查,可能产生边际效应等错误。宏定义时不赋初始值不会报错,宏调用会在编译前由预处理器用宏的展开代码替换掉。因此如果宏定义没有提供可替换的展开代码,预处理时就只会将所有的宏调用删除掉,而那些调用宏的地方在编译时就有可能报错;
const常量是常量的声明,有类型区别,需要在编译阶段进行类型检查,并且在定义的时候就需要赋值,否则会报错。
2、编译器处理不同:宏定义是一个"编译时"概念,在预处理阶段展开,不能对宏定义进行调试;
const常量是一个"运行时"概念,在程序运行使用,类似于一个只读行数据。
3、存储方式不同:宏定义是直接替换,不会分配内存,存储在程序的代码段空间;
const常量需要进行内存分配,存储在程序的数据段中。
4、定义域不同:宏定义不受定义域限制。
const常量仅在定义的代码块中有效,受定义域限制。
5、定义后能否取消:宏定义可以通过#undef来使之前的宏定义失效,失效后也可以重新定义。
const常量定义后将在定义域内永久有效。
6、是否可以做函数参数:宏定义不能作为参数传递给函数。
const常量可以在函数的参数列表中出现。
7、两种方式定义的数的范围不一样:void defineAndConstScope()
{
const int logs = 1e10;
//赋值超过int类型最大范围
//故此时结果为2^31-1
cout << logs << endl;
return ;
}
void defineAndConstScope()
{
//赋值超过unsigned int类型最大范围
//故此时结果为2^32-1
const unsigned int logs = 1e10;
cout << logs << endl;
return ;
}
void defineAndConstScope()
{
//long long int等于long long类型
const long long logs = 1e10;
cout << logs << endl;
return ;
}
#define LOGS 1e8
void defineAndConstScope()
{
cout << LOGS << endl;
return ;
}
#define LOGS 1e7
void defineAndConstScope()
{
cout << LOGS << endl;
return ;
}
综上可以看出const可以自由定义数据类型,以此控制数据的范围,但是#define宏定义则是不可以自由定义数据大小的。
const关键字应用
- 欲阻止一个变量被改变,可使用const,在定义该const变量时,需先初始化,以后就没有机会改变他了;
- 对指针而言,可以指定指针本身为const,也可以指定指针所指的数据为const,或二者同时指定为const;
- 在一个函数声明中,const可以修饰形参表明他是一个输入参数,在函数内部不可以改变其值;
- 对于类的成员函数,有时候必须指定其为const类型,表明其是一个常函数,不能修改类的成员变量;
- 对于类的成员函数,有时候必须指定其返回值为const类型,以使得其返回值不为“左值”。



