qt c++对象头文件如何相互包含

今天在写qt时,遇到了两个类相互包含的问题,类A要用到类B,类B要用到类A。

类A:a.h

#ifndef A_H
#define A_H

#include <b.h>

class A
{
public:
    A();
};
#endif // A_H

a.cpp

#include "a.h"

A::A()
{
    B b;
}

类B:b.h

#ifndef B_H
#define B_H

#include <a.h>

class B
{
public:
    B();
};
#endif // B_H

b.cpp

#include "b.h"

B::B()
{
    A a;
}

按上面这种写法编译是有问题的。

对于a.cpp,包含了a.h,所以先将a.cpp展开,如下

#ifndef A_H
#define A_H

#include <b.h>

class A
{
public:
    A();
};

#endif // A_H

A::A()
{
    B b;
}

这样其实还看不出来,所以继续对#include <b.h>展开,展开时还需加上b.cpp里的代码,如下

#ifndef A_H
#define A_H

#ifndef B_H
#define B_H

#include <a.h> //对于这一句,由于第二行定义过A_H,将不会在对其展开,所以这一句可以去掉。

class B
{
public:
    B();
};

#endif // B_H

B::B()
{
    A a;
}

class A
{
public:
    A();
};

#endif // A_H

A::A()
{
    B b;
}

看上面代码会发现B类的构造函数里使用的A在A类的声明之前,所以问题就出现了,A类未定义。

所以解决的办法就是添加前置声明,在包含头文件的直接前面或者直接后面加上这个类的声明,对于上面这个例子,解决方式就是在类的头文件中加上包含类的前置声明,如下:

a.h

#ifndef A_H
#define A_H

class B;
#include <b.h>
//class B;

class A
{
public:
    A();
};

#endif // A_H

b.h

#ifndef B_H
#define B_H

class A;
#include <a.h>
//class A;

class B
{
public:
    B();
};

#endif // B_H
时间: 2024-10-15 02:56:16

qt c++对象头文件如何相互包含的相关文章

头文件的相互包含会导致错误

互相定义各自的对象会产生: error C2143: syntax error : missing ';' before '*' 无论是定义对象还是定义对象的指针都会报错 这是头文件的相互包含导致的错误

防止头文件的重复包含问题

在我们自己编写 C/C++的头文件时,可能会忽略一点:用一些处理机制来避免头文件的重复包含,因为头文件的内容在预编译时是把头文件的内容完全拷贝到引入的地方替换头文件的包含命令,而包含的头文件可能有包含很多内容,所以要是重复包含头文件,可能会使预编译后的源文件代码冗余量很大,造成空间上的浪费. 1. #pragma once 2. #ifndef #define #endif 它们具体实现如下: 假定此时要保证头文件HeadFile.h不会被重复包含,那么两种方法对应的方式如下: 1. #prag

头文件被重复包含,嵌套包含的两层含义

http://www.cnblogs.com/bluestorm/archive/2011/11/04/2298126.html 说明: 写代码的时候头文件命名知道要加 #ifndef xxxx #define xxxx #endif 但是我把实现都放在了 .h文件中,然后出错了...所以头文件包含,只知其一不知其二,恩,就是所谓的 //a.h #ifndef _A_H_ #define _A_H_ int max(int a, int b) { return a > b ? a:b; } #e

两种解决头文件被重复包含方法的联系与区别

在制作C/C++项目的过程中,应该会遇到关于头文件被重复包含的问题,几乎每一个C/C++程序员都应该知道如何来解决这一问题.通常来说,我们通常可以用两种方式来解决这一问题. 第一种 ---- 利用以下形式: #ifndef  __XX_H__                                                                              #ifndef   XX_H #define __XX_H__                    

QT工程添加头文件路径

场景说明 Linux环境下QT创建项目引入第三方库,添加第三方库的头文件包含路径 修改如下 添加json第三方库 .pro文件 中添加:INCLUDEPATH += /root/jsoncpp-master/include 测试是否成功 #include <QCoreApplication> #include "json/reader.h" int main(int argc, char *argv[]) { QCoreApplication a(argc, argv);

&lt;bits/stdc++.h&gt;头文件介绍(包含源代码)

注:转自http://blog.csdn.net/charles_dong2/article/details/56909347,同为本人写的,有部分修改. 之前在一个小OJ上刷题时发现有人是这么写的: #include <bits/stdc++.h> ... 百度了一下,发现<bits/stdc++.h>包含了全部的C++头文件.这样做题时直接敲上一句#include <bits/stdc++.h>而不是很多个#include.很方便,对吧? 不过注意,目前POJ还不支

cocos2d-x 扩充引擎基类功能 引起的头文件重复包含问题的分析

c++ 头文件包含 原因的分析:   c++  头文件的循环引用是指: .h 里面的里面的头文件的相互包含的,引起的重复引用的问题.cpp 里面包含头文件是不存在重复引用的问题(因为CPP没有#ifndef #define #endif 这个). 关键的原因是:#ifndef #define #endif 引起的.  翻译一下就是  如果没有定义 包含, 如果定义了 就不包含了. 由于 宏是全局唯一的,所以只会包含一次.这就是引起重复包含的原因.这些问题的解决办法:http://my.oschi

让QT编译快一点(增加基础头文件)

姚冬,中老年程序员 进藤光.杨个毛.欧阳修 等人赞同 我是来反对楼上某些答案的.我曾经用MFC写了金山词霸(大约20多万行),又用Qt写了YY语音(大约100多万行),算是对两种框架都比较有经验.纠正几个错误的认识. 1. “用Qt写的程序编译比MFC慢”的说法是错误的绝对错误,单位代码行数编译Qt远比MFC快得多,因为Qt库的头文件设计非常好,尽量都使用了前置声明,避免了头文件嵌套,几乎所有类都使用了公有类和私有类的设计,把没必要公开的声明放到私有头文件里,避免了编译时引入过多代码.而MFC没

c++包含头文件好还是重新定义好

A.h struct A { int a; int b; }; B.cpp 在B.cpp里面用到这个结构体 有两种方法 1.自己定义一个一模一样的结构体 struct A { }; 2.包含A.h头文件 第一种感觉有点蛋疼同样的结构体定义两次,是不是重复了 第二种包含别人的头文件,会带来编译的小麻烦,而且这样模块之间的关联性变大了,感觉也不好 大家觉得哪种方法好?为什么呢? 不要重复发明轮子 , 除非这个轮子满足不了你的需求 先问一个问题,如果别人改了struct A,比如删掉了int b或者加