C-基础:关于预编译以及宏
这是没有引入任何头文件时,如果使用"NULL",编译器会报错:没有定义NULL。此时可用下面代码定义。
#undef NULL //#undef 是在后面取消以前定义的宏定义
#if defined(__cplusplus) //区别于#ifdef,#if defined的意思是如果在编译这几行之前,已经定义过(&& || && ||)等标识符 #define NULL 0 //#define是预处理宏定义命令 #else #define NULL ((void *)0)//NULL ((void*)0) C中的“标准”写法,NULL被替换为一个void*类型的指针右值,等于0;由于是void*类型,可以隐式转化为其它类型的指针。 #endif
一,#undef
#undef 是在后面取消以前定义的宏定义,该指令的形式为:#undef 标识符
在此程序中,我们将取消在先前程序中对预处理器的定义。
#include <iostream.h> #include<string.h> #define MAX 5 #undef MAX int _tmain(int argc, _TCHAR* argv[]) { char name[MAX]="abcd"; std::cout<<"MAX = "<<MAX<<std::endl; for(int i=0;i<MAX;i++) std::cout<<name<<" "<<std::endl; system("pause"); return 0; }
得到错误消息:未定义符号 '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" 这个文件宏定义释放掉,就是这个意思。
在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; }