Effective C++ (3) 避免C++头文件的多重包含
来源:互联网 发布:centos 7安装ngrok 编辑:程序博客网 时间:2024/05/16 10:09
以前在编写程序的时候,经常重复包含头文件(当然以前也不知道有这个问题,知识太有限,只是课本上的),带来众多的问题都不好查找,副作用太大,现在终于知道该如何避免这个问题。
1: #ifndef SALESITEM_H
2: #define SALESITEM_H
3: // Definition of Sales_itemclass and related functions goes here
4: #endif
头文件应该含有保护符,即使这些头文件不会被其他头文件包含。编写头文件保护符并不困难,而且如果头文件被包含多次,它可以避免难以理解的编译错误。
在编写头文件之前,我们需要引入一些额外的预处理器设施。预处理器允许我们自定义变量。
预处理器变量 的名字在程序中必须是唯一的。任何与预处理器变量相匹配的名字的使用都关联到该预处理器变量。
为了避免名字冲突,预处理器变量经常用全大写字母表示。
预处理器变量有两种状态:已定义或未定义。定义预处理器变量和检测其状态所用的预处理器指示不同。#define指示接受一个名字并定义该名字为预处理器变量。#ifndef指示检测指定的预处理器变量是否未定义。如果预处理器变量未定义,那么跟在其后的所有指示都被处理,直到出现#endif。
可以使用这些设施来预防多次包含同一头文件:
#ifndef SALESITEM_H #define SALESITEM_H // Definition of Sales_itemclass and related functions goes here #endif
条件指示
#ifndef SALESITEM_H
测试 SALESITEM_H 预处理器变量是否未定义。如果 SALESITEM_H未定义,那么 #ifndef 测试成功,跟在 #ifndef 后面的所有行都被执行,直到发现#endif。相反,如果 SALESITEM_H 已定义,那么 #ifndef指示测试为假,该指示和 #endif 指示间的代码都被忽略。
为了保证头文件在给定的源文件中只处理过一次,我们首先检测 #ifndef。第一次处理头文件时,测试会成功,因为SALESITEM_H 还未定义。下一条语句定义了SALESITEM_H。那样的话,如果我们编译的文件恰好又一次包含了该头文件。#ifndef指示会发现 SALESITEM_H 已经定义,并且忽略该头文件的剩余部分。
头文件应该含有保护符,即使这些头文件不会被其他头文件包含。编写头文件保护符并不困难,而且如果头文件被包含多次,它可以避免难以理解的编译错误。
当没有两个头文件定义和使用同名的预处理器常量时,这个策略相当有效。我们可以为定义在头文件里的实体(如类)命名预处理器变量来避免预处理器变量重名的问题。一个程序只能含有一个名为Sales_item的类。通过使用类名来组成头文件和预处理器变量的名字,可以使得很可能只有一个文件将会使用该预处理器变量。
- Effective C++ (3) 避免C++头文件的多重包含
- Effective C++ (3) 避免C++头文件的多重包含
- C语言#define条件编译避免多重包含头文件
- 避免头文件的多重包含
- 避免头文件的多重包含
- C语言头文件避免重复包含
- C语言头文件避免重复包含
- 避免C语言头文件重复包含
- C语言头文件避免重复包含
- C头文件包含
- C语言头文件避免重复包含、#pragma once和#ifndef的区别
- C语言头文件避免重复包含、#pragma once和#ifndef的区别
- C开发经验3:如何避免重复包含头文件多次
- C头文件相互包含的问题
- C语言头文件的包含顺序
- 头文件多重包含
- c语言头文件包含
- c++:头文件包含问题
- 一元多项式的
- 英语学习网络资源
- Effective C++ (1) C++和C中的Const
- Effective C++ (2) C#中的Const和Readonly
- 修改设置eclipse 中java文件和jsp文件字体的大小
- Effective C++ (3) 避免C++头文件的多重包含
- Effective C++ (4) c++中的命名空间
- Effective C++ (5) 几个关于数组的问题
- Effective C++ (6) 函数的参数传递
- Effective C++ (7) 强制类型转换
- Effective C++ (8) 顺序容器vector,list,deque
- 泛型算法
- 第一回 ,如何写 go 代码
- C++模板