/* 预处理指令 : 宏定义 : 就是将代码中的宏名进行简单的替代,不进行任何运算; 不带参数的宏定义 : 基本格式 : #idefine 宏名 宏值 //程序预处理时,会将代码中,所有的宏名都替代为宏值; 宏名书写规范 : 全部大写,单词之间以"_"分隔; 注 : 切记红定义中,不要以";"结尾,原因在宏定义中默认宏名之后所有的内容均为宏值,因此,一旦以";"结尾,也会将其当做宏值处理; 带参数的宏定义 : 基本格式 : #define 宏名(形参) 宏值 //预处理时,会将接受的实参替代宏值中的形参,而后再将代码中所有的宏名以宏值替代; 形参 : 此处无需写形参的数据类型,因此没有任何意义; 应用 : 此时的宏值多为一行简单代码,而某一单一值; 注 : 如果在代码中,宏名被包裹在""中,则预处理时,宏名不会被宏值替代; 宏的作用域 : 自定义位置起至文件末尾; 提前结束宏的作用域 : #undef 宏名; 宏定义的应用场景 : 常用于记录一些频繁使用且繁琐的数据; 条件编译 : 当条件满足时,就将对应的代码块保留在程序中执行; 基本格式 : #if condition 代码块; #elif condition 代码块; #else 代码块; #endif //当某一个条件满足时,只保留该条件对应的代码块,其他至endif之间的代码块全部删除; 其他写法 : 第一种 : #ifdef 宏名 代码块; #else 代码块; #endif 第二种 : #ifndef 宏名 代码块; #else 代码块; #endif 条件编译的优点 : 1,节省内存,因为不满足条件的代码块均会被删除; 2,常用于调试过程,如当我们为qq写一个用户分组时,需要频繁登陆qq,以查看效果.因此,在调试过程中,我们就可以把自己的用户名,密码写入条件编译中的宏定义中,\ 以节省我们频繁登陆输入用户名,密码浪费的时间,而在上传应用后,只需修改一下条件,即跳转用户登陆; 文件包含 : 也即将其他文件复制替代本文件中文件包含那一行代码; #include <> //会先在编译环境下查找,找不到,再到系统环境下查找指定文件; #include "" //会现在当前文件目录下查找指定文件,找不到,再编译环境下查找,找不到,再到系统环境下查找指定文件; 注 : 重复导入头文件,会降低程序执行效率,因此可利用条件编译,写一个头文件卫士,一旦已经导入了该头文件,就不在重复导入; */