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