奇怪的编译问题 - 无法识别的类没有编译器错误

Weird compilation issue- no compiler errors for unrecognised class

本文关键字:编译器 错误 识别 编译 问题      更新时间:2023-10-16

我有太多代码要发布,但我不断收到重复的编译错误,即在整个项目中无法识别类Orderbk

最奇怪的是,Orderbk中没有实际的编译错误(这可以理解地导致所有其他类无法识别它)。

有人可以给我线索,因为我的编译器在Orderbk内部没有看到问题,但每个引用Orderbk的类都报告它未定义,这可能是什么问题?

1>------ Build started: Project: FXDcr (Intel C++ 13.0), Configuration: Debug x64 ------
1>  Derivative.cpp
1>C:DXDcrFXDcrInstr.h(29): error : identifier "Orderbk" is undefined
1>      Orderbk getOrderbk();
1>      ^
1>  
1>C:DXDcrFXDcrInstr.h(33): error : identifier "Orderbk" is undefined
1>      Orderbk orderbk;
1>      ^
1>  
1>C:DXDcrFXDcrStk.h(35): error : identifier "Orderbk" is undefined
1>          Orderbk orderbk;
1>          ^
1>  
1>  FXDcr.cpp
1>  FXMsg.cpp
1>  Fut.cpp
1>C:DXDcrFXDcrInstr.h(29): error : identifier "Orderbk" is undefined
1>      Orderbk getOrderbk();
1>      ^
1>  
1>C:DXDcrFXDcrInstr.h(33): error : identifier "Orderbk" is undefined
1>      Orderbk orderbk;
1>      ^
1>  
1>C:DXDcrFXDcrStk.h(35): error : identifier "Orderbk" is undefined
1>          Orderbk orderbk;
1>          ^
1>  
1>  Index.cpp
1>C:DXDcrFXDcrInstr.h(29): error : identifier "Orderbk" is undefined
1>      Orderbk getOrderbk();
1>      ^
1>  
1>C:DXDcrFXDcrInstr.h(33): error : identifier "Orderbk" is undefined
1>      Orderbk orderbk;
1>      ^
1>  
1>  Instr.cpp
1>C:DXDcrFXDcrStk.h(13): error : not a class or struct name
1>    class Stock : public Instr {
1>                         ^
1>  
1>C:DXDcrFXDcrStk.h(35): error : identifier "Orderbk" is undefined
1>          Orderbk orderbk;
1>          ^
1>  
1>C:DXDcrFXDcrMappings.h(31): error : identifier "Instr" is undefined
1>      static unordered_map<string, boost::shared_ptr<Instr> > GetDictOfAllInstrs();
1>                                                     ^
1>  
1>  Main.cpp
1>C:DXDcrFXDcrInstr.h(29): error : identifier "Orderbk" is undefined
1>      Orderbk getOrderbk();
1>      ^
1>  
1>C:DXDcrFXDcrInstr.h(33): error : identifier "Orderbk" is undefined
1>      Orderbk orderbk;
1>      ^
1>  
1>  Mappings.cpp
1>C:DXDcrFXDcrInstr.h(29): error : identifier "Orderbk" is undefined
1>      Orderbk getOrderbk();
1>      ^
1>  
1>C:DXDcrFXDcrInstr.h(33): error : identifier "Orderbk" is undefined
1>      Orderbk orderbk;
1>      ^
1>  
1>  Order.cpp
1>  Stock.cpp
1>C:DXDcrFXDcrInstr.h(29): error : identifier "Orderbk" is undefined
1>      Orderbk getOrderbk();
1>      ^
1>  
1>C:DXDcrFXDcrInstr.h(33): error : identifier "Orderbk" is undefined
1>      Orderbk orderbk;
1>      ^
1>  
1>  SIA.cpp
1>C:DXDcrFXDcrInstr.h(29): error : identifier "Orderbk" is undefined
1>      Orderbk getOrderbk();
1>      ^
1>  
1>C:DXDcrFXDcrInstr.h(33): error : identifier "Orderbk" is undefined
1>      Orderbk orderbk;
1>      ^
1>  
1>C:DXDcrFXDcrStk.h(35): error : identifier "Orderbk" is undefined
1>          Orderbk orderbk;
1>          ^
1>  
========== Build: 0 succeeded, 1 failed, 0 up-to-date, 0 skipped ==========

编辑我所有的头文件都是这样的格式:

#ifndef CLASS_H
#define CLASS_H
class CLASS{
};
#endif

每个编译单元中只能包含一次头文件,以避免重复定义。这是通过#ifdef或其他解决方案完成的。

如果你的头文件相互依赖,你会

得到一个头文件循环,这会导致你在问题中提到的错误类型。

下面是一个示例(我只是使用 #pragma once 来表明该文件只包含一次,可能无法在任何地方使用):

头文件a.h

#pragma once
#include "b.h"
class A {
    B b_instance;
};

头文件b.h

#pragma once
#include "a.h"
class B {
    A a_instance;
};

代码文件program.cpp

#include "a.h"
#include "b.h"

编译program.cpp时,首先包含a.ha.h做的第一件事是包括 b.h . 然后b.h尝试包含a.h,但它将被忽略,因为它已经包含在内。当解析 B 类时,它找不到A因为我们还没有走a.h那么远。

一种解决方案是在 heeader 文件中使用指针(如果可能)。

头文件b.h

#pragma once
class A;
class B {
    A *a_instance;
    public:
    int do_stuff();
};

对于class A的这个前向定义,我可以使用指向它的指针,因为编译器总是知道它们的大小。但是,我不能a_instance = new A();或使用A的成员,这必须b.cpp

代码文件b.cpp

#include "a.h"
int B::do_stuff() {
        a_instance = new A();
        // Or this
        A my_instance;
}