宏 undefundef undef 是在后面取消以前定义的宏定义 该指令的形式为 undef 标识符 其中 标识符是一个宏名称 如果标识符当前没有被定义成一个宏名称 那么就会忽略该指令 一旦定义预处理器标识符 它将保持已定义状态且在作用域内 直到程序结束或者使用 undef 指令取消定义 在此程序中 我们将取消在先前程序中对预处理器的定义 include
#undef
#undef 是在后面取消以前定义的 宏定义 该指令的形式为 #undef 标识符 其中,标识符是一个宏名称。如果标识符当前没有被定义成一个宏名称,那么就会忽略该指令。 一旦定义预处理器标识符,它将保持已定义状态且在作用域内,直到程序结束或者使用#undef 指令取消定义。 在此程序中,我们将取消在先前程序中对预处理器的定义。 #include < iostream.h> #include< string.h> #define MAX 5 #undef MAX void main() { char name[MAX]=”abcde”; //只能用abcd,否则会提示说超出长度,原因大概是”/0″字符 cout<<“MAX = “<<MAX<<endl; for(int i=0;i<MAX;i++) cout<<name<<” “<<endl; } 得到如下错误消息 未定义符号 ‘MAX’ 初始值设定项太多 在此程序中对 MAX 定义后又取消了定义。编译该程序时报错。由于未定义 MAX,char name[MAX] 的 数组大小不可用,因此 编译器发出第二个错误消息。 又如 #define TEST_A 1 #define TEST_CLASS_A clase T1 #include “TEST.h” #undef TEST_A #undef TEST_CLASS_A 在这一个文件中使用宏定义:#undef TEST_A 1 #undef TEST_CLASS_A clase T1 出了#include “TEST.h” 这个文件宏定义释放掉 就是这个意思 也就是在文件#include “TEST.h” 中宏定义#define TEST_A 1 #define TEST_CLASS_A clase T1 起作用,过了这一语句宏定义就释放掉了,在test.h里,这个宏是有效的,然后出了这个头文件,又无效了。 :: 在TEST.h(或TEST.cpp)中1就是TEST_A,clase T1就是TEST_CLASS_A clase;只在TEST中有效。 程序示例: 修改已经宏定义的符号常量的值: #include <stdio.h> int main( void ) { #define MAX 200 printf(“MAX= %d/n”,MAX); #undef MAX #define MAX 300 printf(“MAX= %d/n”,MAX); return 0; }
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。
发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/233577.html原文链接:https://javaforall.net