自定义头文件

在头文件中,常常用来做以下三件事情:

  1. 类的定义;
  2. 外部变量的声明;
  3. 函数的声明;

头文件都有一个与之配套的源文件,源文件需要引用对应的头文件。

自己定义的头文件在引用时为双引号。

一般情况下,头文件中只能写声明不能写定义。

extern int a;
extern int a = 100; // 这是错误的
const int a;  // 常量的定义也是可以写的

我们将《C++ Primer 类》中的图书馆类写成头文件有:

// Sales_data.h
# ifndef SALES_DATA_H // 变量没定义的时候为真,ifdef变量定义的时候为真
# define SALES_DATA_H // 把一个名字设定为预处理变量,这个名字其实无所谓,但最好和文件名一致且需要唯一
# include <string>

struct Sales_data {
	// 数据成员
	std::string bookNo;
	unsigned units_sold = 0;
	double revenue = 0.0;
	// 成员函数
	std::string isbn() const { return bookNo; }
	Sales_data& combine(const Sales_data&);
	double avg_price() const;
};
// Sales_data的非成员接口函数
Sales_data& add(const Sales_data&, const Sales_data&);
std::ostream& print(std::ostream&, const Sales_data&);
std::istream& read(std::istream&, const Sales_data&);

#endif // !SALES_DATA_H
// Sales_data.cpp
# include "Sales_data.h"
# include <iostream>
double Sales_data::avg_price() const {
	if (units_sold)
		return revenue / units_sold;
	else
		return 0;
}

Sales_data& Sales_data::combine(const Sales_data& rhs) {
	units_sold += rhs.units_sold;
	revenue += rhs.revenue;
	return *this;
}

//输入交易信息包括ISBN、售出总数和售出价格
std::istream& read(std::istream& is, Sales_data& item) {
	double price = 0;
	is >> item.bookNo >> item.units_sold >> price;
	item.revenue = price * item.units_sold;
	return is;
}
std::ostream& print(std::ostream& os, const Sales_data& item) {
	os << item.isbn() << " " << item.units_sold << " " << item.revenue << " " << item.avg_price();
	return os;
}

Sales_data& add(const Sales_data& lhs, const Sales_data& rhs) {
	Sales_data sum = lhs;
	sum.combine(rhs);
	return sum;
}

关于头文件的自定义,最重要的还是头文件保护符。

比如头文件中的<string>,很可能在主源文件中再被使用一次,因为在我们自定义中的头文件中已经引用了,所以没必要再引用一次,直接用就行。为了避免这种多重包含,所以我们在自定义的时候需要头文件保护符。详细说明看代码部分。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

右边是我女神

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值