头文件 防止重复包含
================
根据#define 和条件编译 #ifdef、#ifndef #else #endif 最经常的使用是 头文件 防止重复包含。
但是 使用
#pragma once
更好,现在 gcc cl.exe 都支持,它不但代码更少,而且不用为宏起名字,更好。
#pragma 说明编译器信息//用法复杂,参考http://baike.baidu.com/view/1451188.htm
#warning 显示编译警告信息
#error 显示编译错误信息
可以在这些条件编译中 给出某条件下的 提醒。比如 要求定义的宏没有定义,就#error,停止编译。
条件编译 中的多个条件,多个宏同时判断
====================
还有 条件编译中 ,比如 同时判断俩条件的
#ifdef ( a && b)该怎么写呢?如果是ifdef 或者 ifndef 就不能这么写了。
得用#if (a==1 && b==2)这种写法了。试着去掉 #define b 2,条件里面的 编译信息 和 输出 就不会显示了。
#include <stdio.h> #include <iostream> using namespace std; int main(int argc,char **argv){ cout<<"main"<<endl; #define a 1 #define b 2 // #ifdef a && #ifdef b #if (a==1 && b==2 ) #pragma message("\npragma message YES Defined a b\n") cout<<"YES Defined a and b??"<<endl; #endif return 0; }
刚发现 ifdef也是可以多个条件的:
类似:#if defined _DEBUG || defined VLD_FORCE_ENABLE
//刚从boost-jam-3.1.18 的源码(sf.net链接)中的pwd.c 中看到的,积累下。 //看来cl貌似还定义了 NT 变量,GNU GCC定义了 __GNUC__ /* MinGW on windows declares PATH_MAX in limits.h */ #if defined(NT) && ! defined(__GNUC__) #include <direct.h> #define PATH_MAX _MAX_PATH #else #include <unistd.h> #if defined(__COMO__) #include <linux/limits.h> #endif #endif
VLD是一个 检测 内存泄漏的编程工具包。值得推荐!以前遇到段错误,或者内存没有合理的释放掉的情况,也不知道该怎么办。用这个 好点。段错误 貌似 无法有效的检测呢。。野指针!