C++学习:类与对象(三)

参考书籍:《c++程序设计》张军编著 第七章,实际为笔记,哈哈

本篇文章主要讲了宏定义,编译预处理与文件包含的内容。


1.编译预处理

1.1  常见问题:例如:要编写头文件test.h
         一般需要在头文件开头写上两行:
          #ifndef _TEST_H
          #define _TEST_H//一般是文件名的大写
         ············
         ············
         头文件结尾写上一行:
          #endif

原因是:

[此处转载自:http://blog.renren.com/share/231327413/566439602]

比如你有两个C文件,这两个C文件都include了同一个头文件。而编译时,这两个C文件要一同编译成一个可运行文件,于是问题来了,大量的声明冲突。
例如:
假设你的工程里面有4个文件,分别是a.cpp,b.h,c.h,d.h。 
a.cpp的头部是: 
#include   "b.h " 
#include   "c.h " 
b.h和c.h的头部都是: 
#include   "d.h " 
而d.h里面有class   D的定义。 
这样一来, 
编译器编译a.cpp的时候,先根据#include   "b.h "去编译b.h这个问题,再根据b.h里面的#include   "d.h ",去编译d.h的这个文件,这样就把d.h里面的class   D编译了; 
然后再根据a.cpp的第二句#include   "c.h ",去编译c.h,最终还是会找到的d.h里面的class   D,但是class   D之前已经编译过了,所以就会报重定义错误。 加上ifndef/define/endif,就可以防止这种重定义错误。

在理论上来说定义identifier 可以是自由命名的,但每个头文件的这个“标识”都应该是唯一的。标识的命名规则一般是头文件名全大写,前后加下划线,并把文件名中的“.”也变成下划线,如:stdio.h   

先来看一下最简单的编译预处理指令,#define和#undef

比如:#define PI  3.14    (当然我们也可以用const int PI=3.14,区别在于const占内存空间,而宏只是标识符,不占用内存空间,且简单些)

即 :#define identifier标识符  string文本串

注意: 1.该语句没有分号,2续行符为反斜杠‘\’     3.普遍用大写字母定义标识符  

至于对应的#undef指令的作用是删除由#define定义的宏。

1.2 常用编译指令/条件编译指令

//如果identifier为一个定义了的标识符,code就会编译
#ifdef identifier
           code
#endif

//如果identifier为一未定义的标识符,code就会编译
#ifndef identifier
           code
#endif

//如果常量表达式为非0,code就会编译
#if constant_expression
    code
#endif

//(4) 
#ifdef identifier
    code1
#else
    code2
#endif

//(5)
#ifdef constant_expression
    code1
#elif constant_expression2
    code2
#else
    code3
#endif

2.程序的组织架构

一般由 类的声明(抽象的定义)、类的成员函数的实现、主函数构成

一般把类的声明放.头文件;成员函数定义实现放.cpp,主函数放main.cpp里面

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值