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 标识符

其中,标识符是一个宏名称。如果标识符当前没有被定义成一个宏名称,那么就会忽略该指令。
一旦定义预处理器标识符,它将保持已定义状态且在作用域内,直到程序结束或者使用#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',初始值设定项太多

在此程序中对 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" 这个文件宏定义释放掉,就是这个意思。

在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;
}

 

 

posted @ 2013-09-13 09:23  CPYER  阅读(198)  评论(0编辑  收藏  举报