1、基本概念

  条件编译的行为类似于C语言中的if…else…

  条件编译是预编译指示命令,用于控制是否编译某段代码

2、实例分析

条件编译初探     22-1.c

 #include <stdio.h>  
  
#define C 1  
  
int main()  
{  
    const char* s;  
  
    #if( C == 1 )  
        s = "This is first printf...\n";  
    #else  
        s = "This is second printf...\n";  
    #endif  
  
    printf("%s", s);  
      
    return ;  
}  

3、条件编译的本质

  预编译器根据条件编译指令有选择的删除代码

  编译器不知道代码分支的存在

  if. .. else ... 语句在运行期进行分支判断

  条件编译指令在预编译期进行分支判断

  可以通过命令行定义宏

 -  gcc -Dmacro=value file.c 或 gcc -Dmacro file.c

4、#include的本质

  #include的本质是将已经存在的文件内容嵌入到当前文件中

  #include的间接包含同样会产生嵌入文件内容的操作

如何解决间接包含同—个头文件产生编译错误?

解决方案:

 #ifndef _HEADER_FILE H   
  
#define _HEADER_FILE H   
  
  // source code   
  
#endif   

5、实例分析

条件编译的使用

global.h

 // global.h  
#ifndef _GLOBAL_H_  
#define _GLOBAL_H_  
int global = ;  
  
#endif  

test.h

 // test.h  
  
#ifndef _TEST_H_  
#define _TEST_H_  
#include "global.h"  
  
const char* NAME = "test.h";  
char* hello_world()  
{      
    return "Hello world!\n";  
}  
  
#endif  

22-3.cpp

 //#include <stdio.h>  
#include "test.h"  
#include "global.h"  
  
int main()  
{  
    const char* s = hello_world();  
    int g = global;  
      
    // printf("%s\n", NAME);  
    // printf("%d\n", g);  
      
    return ;  
}  

条件编译可以解决头文件重复包含的编译错误

7、条件编译的意义

  条件编译使得我们可以按不同的条件编译不同的代码段,因而可以产生不同的目标代码

  #if…#else…#endif被预编译器处理,而if…else .. 语句被编译器处理,必然被编译进目标代码

实际工程中条件编译主要用于以下两种情况:

-不同的产品线共用一份代码

-区分编译产品的调试版和发布版

8、实例分析

产品线区分及调试代码应用     product.h     22-4.c

product.h

 #define DEBUG 1  //调试版
#define HIGH  1  //高端产品

22-4.c

 #include <stdio.h>  
#include "product.h"  
  
#if DEBUG  
    #define LOG(s) printf("[%s:%d] %s\n", __FILE__, __LINE__, s)  
#else  
    #define LOG(s) NULL  
#endif  
  
#if HIGH  
void f()  
{  
    printf("This is the high level product!\n");  
}  
#else  
void f()  
{  
}  
#endif  
  
int main()  
{  
    LOG("Enter main() ...");  
      
    f();  
      
    printf("1. Query Information.\n");  
    printf("2. Record Information.\n");  
    printf("3. Delete Information.\n");  
      
    #if HIGH  
    printf("4. High Level Query.\n");  
    printf("5. Mannul Service.\n");  
    printf("6. Exit.\n");  
    #else  
    printf("4. Exit.\n");  
    #endif  
      
    LOG("Exit main() ...");  
      
    return ;  
}  

9、小结

通过编译器命令行能够定义预处理器使用的宏

条件编译可以避免围复包含头同—个头文件

条件编译是在工程开发中可以区别不同产品线的代码

条件编译可以定义产品的发布版和调试版

C语言-条件编译使用分析的更多相关文章

  1. (五)c语言条件编译#ifdef与#if defined

    c语言条件编译#ifdef与#if defined defined NAME是用来判断NAME是否被定义了(被用define定义了). #ifdef NAME == #if defined(NAME) ...

  2. 利用R语言打造量化分析平台

    利用R语言打造量化分析平台 具体利用quantmod包实现对股票的量化分析 1.#1.API读取在线行情2.#加载quantmod包3.if(!require(quantmod)){4. instal ...

  3. R语言重要数据集分析研究——需要整理分析阐明理念

    1.R语言重要数据集分析研究需要整理分析阐明理念? 上一节讲了R语言作图,本节来讲讲当你拿到一个数据集的时候如何下手分析,数据分析的第一步,探索性数据分析. 统计量,即统计学里面关注的数据集的几个指标 ...

  4. c语言条件编译#ifdef与#if defined

    c语言条件编译#ifdef与#if defined   c语言条件编译#ifdef与#if defined 摘自:https://www.cnblogs.com/zhangshenghui/p/566 ...

  5. Go语言的前景分析

    本文为原创文章,转载注明出处,asdfasdfasdf 欢迎扫码关注公众号flysnow_org或者网站http://www.flysnow.org/,第一时间看后续精彩文章.觉得好的话,顺手分享到朋 ...

  6. Go将统治下一个10年?Go语言发展现状分析

    “本文是国内Go语言大中华区首席布道师——许式伟,在QCon2015上海站上的分享.他预测Go语言10年内一定会超过C和java,并且统治这一个10年. Go语言语法及标准库变化 Go从1.0版本到现 ...

  7. 猴子吃桃问题之《C语言经典案例分析》

    猴子吃桃问题之<C语言经典案例分析>一.[什么是猴子吃桃]       猴子吃桃问题:猴子第一天摘下若干个桃子,当即吃了一半,还不过瘾,又多吃了一个.第二天早上又将第一天剩下的桃子吃掉一半 ...

  8. Go语言源码分析之unsafe

    Go语言源码分析之unsafe 1.什么是unsafe unsafe 库让 golang 可以像C语言一样操作计算机内存,但这并不是golang推荐使用的,能不用尽量不用,就像它的名字所表达的一样,它 ...

  9. Go语言的堆栈分析

    本文为理解翻译,原文地址:http://www.goinggo.net/2015/01/stack-traces-in-go.html Introduction 在Go语言中有一些调试技巧能帮助我们快 ...

随机推荐

  1. amr格式转mp3和直接播放amr格式的文件-sunziren

    原创文章,转载请注明出处! 前言: amr作为一种高压缩比的音频格式,受到很多客户的青睐.本文主要涉及两部分的内容,一是amr如何转为mp3格式,二是如何直接播放amr格式的文件. 1. 如何使用Ja ...

  2. javascript 基础整理

    js编码标准 参考 数据类型 注意事项

  3. AQS源码分析总结

    AQS是并发编程的一个最基本组件,是一个抽象同步器. 网上有很多详细介绍AQS的博文,在这里我就不仔细介绍了,主要写一些重要的内容. AQS中重要的几个属性: //同步队列的头节点 private t ...

  4. spring中JdbcTemplate使用

    1.maven依赖 <?xml version="1.0" encoding="UTF-8"?> <project xmlns="h ...

  5. Wannafly Winter Camp 2020 Day 5C Self-Adjusting Segment Tree - 区间dp,线段树

    给定 \(m\) 个询问,每个询问是一个区间 \([l,r]\),你需要通过自由地设定每个节点的 \(mid\),设计一种"自适应线段树",使得在这个线段树上跑这 \(m\) 个区 ...

  6. Sass环境安装-Sass sublime 编辑器插件编译方法

    首先官网(http://www.ruby-lang.org/en/downloads/)下载 ruby (1)打开链接进入到下载页面,点击如下位置进行下载 (2)下载页面 (3)进入到各个版本的列表页 ...

  7. 网络共享服务(一)之FTP

    网络共享服务:ftp,nfs,samba比较 从跨平台角度说, samba, ftp差不多, 而nfs不支持windows平台 从挂载角度说, samba, nfs可以把远程目录挂载到本地目录上, 对 ...

  8. 51Nod 1183 编辑距离 (字符串相似算法)

    编辑距离,又称Levenshtein距离(也叫做Edit Distance),是指两个字串之间,由一个转成另一个所需的最少编辑操作次数.许可的编辑操作包括将一个字符替换成另一个字符,插入一个字符,删除 ...

  9. [CF1303F] Number of Components - 并查集,时间倒流

    有一个 \(n \times m\) 矩阵,初态下全是 \(0\). 如果两个相邻元素(四连通)相等,我们就说它们是连通的,且这种关系可以传递. 有 \(q\) 次操作,每次指定一个位置 \((x_i ...

  10. Blue Jeans[poj3080]题解

    题目 Description - The Genographic Project is a research partnership between IBM and The National Geog ...