0x01 什么是头文件?
1、C++程序一般都会有两类文件,一类用于保存程序的声明,即称为头文件(Header),另一类用于保存程序的定义及实现;
2、头文件以 .h 为后缀;
3、头文件的作用在于调用库资源,用户只需包含对应库的头文件,即可使用库的功能而不用去关心该功能如何实现。同时,头文件还可为程序调试提供方便,如果用户对接口的使用和实现方式与头文件中的规范不一致,编译器就会指出错误,这样可以方便程序员的调试及修改。
0x02 头文件的组成
头文件由三个部分的内容组成:
1、版权及版本声明(一般注释于头文件开头)
2、预处理块;
3、函数和类结构的声明等(头文件一般只放只能被定义一次的实体,例如类、const变量、constexpr变量等,但尽量只是“声明”它们)。
0x03 头文件的书写规范
1、标明版权、版本及用途有利于使用者快速理解;
2、建议只存放“声明”而不“定义”,虽然C++允许在头文件中同时声明及定义,但这样做造成了风格不统一,会令程序可读性下降,无论是阅读还是修改都不方便;
3、习惯性地加上头文件保护符,防止头文件被重复引用是非常必要的。
Preprocessor variables have one of two possible states: defined or not defined. The #define directive takes a name and defines that name as a preprocessor variable. There are two other directives that test whether a given preprocessor variable has or has not been defined: #ifdef is true if the variable has been defined, and #ifndef is true if the variable has not been defined. If the test is true, then everything following the #ifdef or #ifndef is processed up to the matching #endif.4、头文件不应该包含using之类的声明。
#ifndef SALES_DATA_H
#define SALES_DATA_H //头文件保护符,如果没有定义Sales_data,则定义它
#include <string>
struct Sales_data
{
std::string bookNo;
unsigned units_sold = 0;
double revenue = 0.0;
};
#endif //涉及预处理知识点,现在这里先这么记住就行
0x04 头文件的引用
1、包含来自标准库的头文件时,用尖括号< >包围头文件名;
2、对于不属于标准库的头文件,则使用双引号“ ”包围。
#include <iostream>
#include "Sales_data.h"
int main(int argc, const char * argv[])
{
return 0;
}
-----------(我是分割线)-----------
这里的学习顺序基于《 C++ Primer(第五版)》,虽说这本书是C++神书,但如果没有一定的C语言基础,肯定很难一下子啃下来,特别是原书第一章说编写一个简单的程序,结果各种语句和输入输出流都出现了,最后还来个类简介,实在是有点让新手朦逼。就算有一定的C++基础,中文版的语言也略显拗口。
所以,我建议可以先用谭浩强的C/C++系列高校用书籍来打个基础。先别管网上对谭教授的教材评价如何,至少它能高效地带你入门。直接学习C++不是不可以,但毕竟C语言是一门经典的计算机语言,经久不衰,还衍生出了很多其他的计算机语言。学好C语言能培养出一种理解计算机语言的思维模式,以后学其他语言都可能事半功倍。
我个人的学习方式是“先看懂,后深入,再高效”。在这里会按照我的理解,尽量用简单的语言来解释C++的知识点,至少先看懂并让程序能用再说。如果有错欢迎指正。
文中可能有某些程序段来自pezy大神,自学C++的路上我有很多疑难都是在pezy大神的解释中顿悟。在此表示感谢!
任何地方如有侵权请立即联系删除。
-----------(我是分割线)-----------