C和指针 第十四章 预处理器 头文件
编写一个C程序,第一个步骤称为预处理,预处理在代码编译之前,进行一些文本性质的操作,删除注释、插入被include的文件、定义替换由#define定义的符号,以及确定代码的部分内容是否应该按照条件编译
共有五个预处理指令:
预定义指令:define
条件编译:#if, #elif,#else,#endif,#ifdef,#ifndef
文件包含#include
编译错误:#error指令
#progma指令
一、预定义指令:define
#define name stuff
define为数值命名一个符号,每当有name出现时,就会被替换成stuff。多行命名可以用\分隔开每行。define机制包括一个规定,允许把参数替换到文本中,称为宏(macro).
#define name(paramater-list) stuff
其中parameter-list是由逗号分隔的符号列表,可以出现在stuff中。name和左括号直接不可以有空格,不然会被当做stuff一部分处理。
#define MUT(x, y) x *y
如果MUT(3+1, 1+2)会被展开成:
3+1 * 1+ 2
为了避免宏展开时,参数中操作符或邻近操作符之间作用,导致意外,应该使用括号将宏参数括起来。
#define MUT(x, y) (x) *(y)
#define替换
预处理时,字符串常量的值并不进行检查,所以如果需要把宏参数,插入到字符串中,有两种方法:
1.该方法只可以用于字符串参数,利用字符串相邻自动链接特性。
#include <stdio.h>
#define PRINT(FORMAT, VALUE) printf("The FORMAT is "FORMAT"\n", VALUE) int main()
{
PRINT("%d", 10);
return 0;
}
该方法只可以用于字符串。运行:
2.利用define预处理的宏参数进行转换,#arg被替换成arg代表的参数的字符串形式"arg"。
#include <stdio.h>
#define PRINT(FORMAT, VALUE) printf("The "#VALUE" value is "FORMAT"\n", VALUE) int main()
{
int x = 1;
PRINT("%d", x + 10);//x+10被替换成"x+10"
return 0;
}
运行:
宏与函数:
#define MAX(x,y) ((x) > (y) ? (x) : (y))
表达式中求较大值,利用宏来实现的优点是,宏是无类型的,但是会在每一处调用进行展开。宏还可以做一些函数无法实现的
#define MALLOC(n, type) ((type *)malloc(sizeof (type) * (n)))
申请n个type类型的内存空间
#include <stdio.h>
#include <stdlib.h>
#include <string.h> #define MALLOC(n, type) ((type *)malloc(sizeof (type) * (n))) int main()
{
char *str;
str = MALLOC(10, char);
strcpy(str, "yang");
printf("%s", str); return 0;
}
运行:
带副作用的宏:
如果宏参数在宏定义中出现次数超过一次,这个参数如果具有副作用,那么这个宏带有副作用。
#include <stdio.h> #define MAX(x, y) ((x) > (y) ? (x) : (y)) int main()
{
int x = 1;
int y = 2;
printf("%d", MAX(++x, ++y)); return 0;
}
运行:++具有副作用
#undef 移除一个宏定义
#include <stdio.h> #define NUM 100 int main()
{ printf("%d",NUM);
#undef NUM
printf("%d", NUM);//此处将报错,以及移除宏定义了 return 0;
}
运行:
二、条件编译:#if, #elif,#else,#endif,#ifdef,#ifndef
利用条件编译,可以选择代码一部分是正常编译还是完全忽略。
#include <stdio.h>
#define DEBUG 1 //#if对后面的表达式求值,如果非零(真)那么运行
#if DEBUG
#define NUM -100
#else
#define NUM 100
#endif int main()
{
printf("%d",NUM); return 0;
}
还支持#elif, 运行:
是否被定义:#ifdef , #ifndef
#ifdef DEBUG
#define NUM -100
#else
#define DEBUG 1
#define NUM 100
#endif
三、 文件包含#include
#include指令使另一个文件的内容被加入,被编译。当应用系统函数库文件时,使用中括号
#include <file.h>
当引入本地文件时,使用双引号
#include "file.h"
编译器先在本地查找头文件,如果找不到再去系统标准位置查找。
如果一个头文件,被多个文件包含,多个文件直接互相包含,会导致多次包含。可以使用条件编译,使头文件只被包含一次。
#ifndef __HEADFILE_H
#define __HEADFILE_H
//然后进行函数的声明等等
#endif
这样头文件,就只会被包含一次。但预处理器仍将读取这个文件,只是文件内容会被忽略。
四、#error指令
用于编译时生成错误信息
#ifndef SUCCESS
#error NO SUCCESS
#endif
五、#progma指令
因编译器而异,允许一些编译选项或其他方式无法实现的一些处理方式。如把汇编插入到C代码中
C和指针 第十四章 预处理器 头文件的更多相关文章
- C和指针 第十四章 习题
14.1 打印函数 #include <stdio.h> void print_ledger_long(){ printf("function print_ledger_long ...
- C和指针 (pointers on C)——第十四章:预处理器
第十四章 预处理器 我跳过了先进的指针主题的章节. 太多的技巧,太学科不适合今天的我.但我真的读,读懂.假设谁读了私下能够交流一下.有的小技巧还是非常有意思. 预处理器这一章的内容.大家肯定都用过.什 ...
- 《Linux命令行与shell脚本编程大全》 第十四章 学习笔记
第十四章:呈现数据 理解输入与输出 标准文件描述符 文件描述符 缩写 描述 0 STDIN 标准输入 1 STDOUT 标准输出 2 STDERR 标准错误 1.STDIN 代表标准输入.对于终端界面 ...
- JavaScript高级程序设计:第十四章
第十四章 一.表单的基础知识 在HTML中,表单是由<form>元素来表示的,而在javascript中,表单对应的则是HTMLFormElement类型.HTMLFormElement继 ...
- 第十四章——循环神经网络(Recurrent Neural Networks)(第一部分)
由于本章过长,分为两个部分,这是第一部分. 这几年提到RNN,一般指Recurrent Neural Networks,至于翻译成循环神经网络还是递归神经网络都可以.wiki上面把Recurrent ...
- C++ Primer Plus学习:第十四章
第十四章 C++中的代码重用 包含对象成员的类 将类的对象作为新类的成员.称为has-a关系.使用公有继承的时候,类可以继承接口,可能还有实现(纯虚函数不提供实现,只提供接口).使用包含时,可以获得实 ...
- 进击的Python【第十四章】:Web前端基础之Javascript
进击的Python[第十四章]:Web前端基础之Javascript 一.javascript是什么 JavaScript 是一种轻量级的编程语言. JavaScript 是可插入 HTML 页面的编 ...
- 【C++】《C++ Primer 》第十四章
第十四章 重载运算与类型转换 一.基本概念 重载运算符是具有特殊名字的函数:由关键字operator和其后要定义的运算符号共同组成.也包含返回类型.参数列表以及函数体. 当一个重载的运算符是成员函数时 ...
- 【odoo14】第十四章、CMS网站开发
第十四章.CMS网站开发** Odoo有一个功能齐全的内容管理系统(CMS).通过拖放功能,你的最终用户可以在几分钟内设计一个页面,但是在Odoo CMS中开发一个新功能或构建块就不是那么简单了.在本 ...
随机推荐
- python3下urlopen解析中文url编码错误
这是在ipython下测试的结果: In [24]: x Out[24]: 'http://127.0.0.1:8000/xxx/?id=a45ex0bad3c9&game=五子棋' In [ ...
- 十连测Day1 题解
A. 奥义商店 有一个商店,n个物品,每个物品有一个价格和一种颜色. 有m个操作,操作有两种,一种是修改一个位置的价格,另一种是购买,每次购买指定一个公差d和一个位置k,找到包含这个位置k公差为d的同 ...
- Permutations
Permutations Given a collection of distinct numbers, return all possible permutations. For example,[ ...
- #1014 Trie树
本题主要是求构造一棵Trie树,即词典树用于统计单词. C#代码如下: using System; using System.Collections.Generic; using System.Lin ...
- ipad
1. ipad pro 与 ipad air2 时间已经是2016.12.9, 苹果还没有推出新的ipad产品,有些纠结于哪款更适合自己,总结下产品不易获取的核心配置信息 ipad air2 ram ...
- 递推 HDU 1143
n%2==1 0 n%2==0 右边和左边没影响 右边的 * 左边的 z[n]=3*z[n-2]+2*z[n-4]+...2*z[0]; z[n-2]=3*z[n-4]+2*z[n-6]+...2*z ...
- 由Memcached升级到 Couchbase的 Java 客户端的过程记录(二)
Shiro提供了类似于Spring的Cache抽象,即Shiro本身不实现Cache,但是对Cache进行了又抽象,方便更换不同的底层Cache实现. shiro对缓存的支持 shiro并没有实现缓存 ...
- Angular作用域的层级概念(scope)
首先引入 angular 的根作用域:$rootScope ng-app:定义了angualr的作用域 ng-controller:定义了控制器 $scope定义了视图与控制器之间的纽带,而scope ...
- Asynchronous fs.stat.isDirectory()
function showFile() { for(var i = 0; i< files.length; i++){ var itemFile = files[i]; fs.stat(__di ...
- BZOJ3631: [JLOI2014]松鼠的新家
传送门 树上的差分优化,很简单的一道题,应该属于NOIP2015TGD2T3的子问题. //BZOJ 3631 //by Cydiater //2016.10.25 #include <iost ...